赞
踩
这个轮播图的样式是参照奔驰官网的,原始效果图大概是这样
轮播图下面的小圆圈呈现出中间大,两边小的效果。先来看看最终的成品:
分析:假设按照奔驰官网的一样,轮播的图片有6张。明显可以看出,每个大圆的一侧最多有两个小圆,且小圆的半径依次在减小。
实现的功能有:
点击左右键能切换图片;点击小圆圈能切换图片,实现自动轮播;当鼠标放上去停止自动播放;大概鼠标离开后能自动播放。
完整代码(含详细注释):
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <style> * { margin: 0; padding: 0; } li { list-style: none; } .big_box { position: relative; width: 500px; height: 400px; margin: 100px auto; overflow: hidden; } .big_box ul { position: absolute; left: 0; width: 700%; height: 400px; } .big_box ul li { float: left; } .big_box ul li img { width: 500px; height: 400px; } .left { position: absolute; top: 50%; left: 0; transform: translateY(-50%); background-color: rgba(0, 0, 0, 0.5); width: 30px; height: 30px; line-height: 30px; text-align: center; color: white; } .right { position: absolute; top: 50%; right: 0; transform: translateY(-50%); background-color: rgba(0, 0, 0, 0.5); width: 30px; height: 30px; line-height: 30px; text-align: center; color: white; } .big_box ol { position: absolute; bottom: 0; /* 这里别给ol限制宽度,让小圆圈的个数自动把ol撑大 */ left: 50%; transform: translateX(-50%); height: 10%; line-height: 10%; text-align: center; } .big_box ol li { float: left; width: 20px; height: 20px; background-color: rgba(255, 255, 255, .5); border-radius: 50%; margin-left: 5px; display: none; } .big_box ol .current { background-color: rgb(211, 29, 29); display: block; } /* 第一层的样式 */ .big_box ol .current1 { width: 15px; height: 15px; display: block; margin-top: 2.5px; } /* 第二层的样式 */ .big_box ol .current2 { margin-top: 5px; width: 10px; height: 10px; display: block; } .left, .right, ol li { cursor: pointer; } </style> </head> <body> <div class="big_box"> <!-- 轮播的图片 --> <ul> <li> <img src="imgs/picture1.png" alt=""> </li> <li> <img src="imgs/picture7.png" alt=""> </li> <li> <img src="imgs/picture3.png" alt=""> </li> <li> <img src="imgs/picture4.png" alt=""> </li> <li> <img src="imgs/picture5.png" alt=""> </li> <li> <img src="imgs/picture6.png" alt=""> </li> </ul> <!-- 左右按键 --> <div class="left"><</div> <div class="right">></div> <!-- 小圆圈 --> <ol> </ol> </div> <script> var timer; var big_box = document.querySelector('.big_box'); var ul = big_box.querySelector('ul'); var ol = big_box.querySelector('ol'); var lis_img = ul.querySelectorAll('li'); var left = document.querySelector('.left'); var right = document.querySelector('.right'); var num = 0; //记录要滑到第几张图片 function animate(obj, target) { var timer1 = setInterval(function () { var current = obj.offsetLeft; var step = 10; step = current > target ? -step : step; // 下面要包括等于的情况,否则会发生抖动 if (Math.abs(current - target) <= Math.abs(step)) { clearInterval(timer1); obj.style.left = target + 'px'; } else { obj.style.left = current + step + 'px'; } }, 10) } //小圆圈样式改变-----最关键的步骤 function circlechange(circles, circle) { //circle是当前所展示的图片的索引,也是要改变样式的圆圈的索引 if (circle == lis_img.length) { circle = 0; } //排他思想设置小圆圈样式 //排他思想第一步:先把所有的小圆圈样式去掉 for (var i = 0; i < circles.length; i++) { circles[i].className = ""; } //排他思想第二步:把当前图片对应的小圆圈设置样式 circles[circle].className = "current"; //大圆左边的两个圆 if (circle - 1 >= 0) { circles[circle - 1].className = "current1"; } if (circle - 2 >= 0) { circles[circle - 2].className = "current2"; } //大圆右边的两个圆 if (circle + 1 <= lis_img.length - 1) { circles[circle + 1].className = "current1"; } if (circle + 2 <= lis_img.length - 1) { circles[circle + 2].className = "current2"; } } //在页面刚加载进来就执行代码 window.addEventListener('load', function () { //设置小圆点的个数 for (var i = 0; i < lis_img.length; i++) { var li = document.createElement('li'); ol.appendChild(li); // 给小圆圈添加自定义属性 li.setAttribute('index', i); //一开始第一个小圆圈就是被选中状态 if (i == 0) { li.className = "current"; } //给小圆圈添加点击处理事件 li.addEventListener('click', function () { //排他思想实现小圆圈样式改变 for (var j = 0; j < ol.children.length; j++) { ol.children[j].className = ""; } this.className = "current"; //实现点击小圆圈后图片滑动 var index = this.getAttribute('index'); animate(ul, -index * big_box.offsetWidth); // 在图片滑动的同时对应的小圆圈样式也要发生改变,所以调用animate函数同时调用circlechange函数 circlechange(circles, index); }) } //为了实现无缝衔接的切换图片,要把第一张图片克隆到最后一张图片的附近 var circles = ol.querySelectorAll('li'); // cloneNode函数若括号里面是true,则是深拷贝,false则是浅拷贝 var li_img = ul.children[0].cloneNode(true); ul.appendChild(li_img); //点击右箭头向右滑动 right.addEventListener('click', function () { //下面if代码是实现向右滑动的无缝衔接,不懂的建议自己手动模拟一遍 if (num >= lis_img.length) { num = 0; //注意改变属性left的值后面一定要跟px,否则没有效果 ul.style.left = 0 + 'px'; } num++; animate(ul, -num * big_box.offsetWidth); circlechange(circles, num); }) //点击左箭头向左滑动 left.addEventListener('click', function () { //下面if代码是实现向左滑动的无缝衔接,不懂的建议自己手动模拟一遍 if (num <= 0) { num = lis_img.length; ul.style.left = -lis_img.length * big_box.offsetWidth + 'px'; } num--; animate(ul, -num * big_box.offsetWidth); circlechange(circles, num); }) //实现自动播放----因为自动播放的功能和向右滑动的功能一样,所以直接调用向右滑动的函数 timer = setInterval(function () { right.click(); }, 2000) //鼠标放到盒子上停止自动播放 big_box.addEventListener('mouseover', function () { clearInterval(timer); }) //鼠标离开自动播放 big_box.addEventListener('mouseout', function () { clearInterval(timer); //在重新创建一个定时器时最好先清除一下定时器 timer = setInterval(function () { right.click(); }, 2000) }) }) </script> </body> </html>
代码中所用到的图片素材如下:
赞
踩
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。