图片轮播

图片轮播的大概功能:

  • 图片是以滑动的方式出现的
  • 可以点击按钮来滑动到上一张和下一张
  • 当下一张没有了,就左滑到下一张。当上一张没有了,就右滑到最后一张
  • 可以点击导航小圆点来跳转到指定的某一张
  • 鼠标在图片外时,图片可以自动滑动
  • 鼠标停留在图片上停止滑动

  其中的难点,核心就是第一点和第三点,做完这两点图片轮播就做了一半了。滑动给人的感觉就是图片在一排,每次整排移动一张图片大小的位置。当最后一张图片滑动时,先将前面所有图片按照原顺序依次排在后面,然后滑动,滑动动画结束后再将最后一张图片还原到最后位置上。我按照这种方式做完后发现图片很混乱,特别是在端点处的照片,不能按照自己的预期滑动。

  然后就有了第二种方法,图片的滑动是给用户看的,每次滑动用户最多看见两张照片,所以我们不必考虑所有图片的排序,我们只需要将这两张排个序,在一起滑个动就行了。左滑到下一张就先把下一张图片移动到当前图片的后面,并一起左滑给用户看。右滑同理也一样。

  查看效果:https://oleolema.github.io/blog/%E5%9B%BE%E7%89%87%E8%BD%AE%E6%92%AD/

贴上代码:

js:

(function () {
    var img4 = [
        "http://ww2.sinaimg.cn/large/6834b4ddjw1f5yf4s5c3kj21jk1117wh.jpg", "http://ww3.sinaimg.cn/large/6834b4ddjw1f5yf5cjkcnj21jk2bce82.jpg", "http://ww3.sinaimg.cn/large/6834b4ddjw1f5yf29ywgzj21jk2bc4qq.jpg", "http://ww1.sinaimg.cn/large/6834b4ddjw1f5yf1jk9a6j21jk1nd1kx.jpg", "http://ww4.sinaimg.cn/large/6834b4ddjw1f5yf1ap491j21jk111kg9.jpg", "http://ww3.sinaimg.cn/large/6834b4ddjw1f5yf12bw82j21jk10m7te.jpg", "http://ww1.sinaimg.cn/large/6834b4ddjw1f5yf0uc0dsj21jk2bckjl.jpg", "http://ww1.sinaimg.cn/large/6834b4ddjw1f5yf0fs65vj21jk1gi7wh.jpg", "http://ww2.sinaimg.cn/large/6834b4ddjw1f5yeyqzzu3j21jk2bce81.jpg", "http://ww4.sinaimg.cn/large/679865b1gw1ehrlfhfw7hj20kd0ukaph.jpg", "http://ww3.sinaimg.cn/large/679865b1gw1ehrlfgckajj20kd0uk46i.jpg", "http://ww4.sinaimg.cn/large/679865b1gw1ehrlf95v9uj20kd0uk101.jpg", "http://ww4.sinaimg.cn/large/679865b1gw1ehrlf95v9uj20kd0uk101.jpg", "http://ww3.sinaimg.cn/large/679865b1gw1ehrlf55rx6j20kd0ukahs.jpg", "http://ww4.sinaimg.cn/large/679865b1gw1ehrlf46olyj20uk0kdtgh.jpg", "http://ww2.sinaimg.cn/large/679865b1gw1ehrlf3a784j20kd0ukdnq.jpg", "http://ww1.sinaimg.cn/large/679865b1gw1ehrlf2atjfj20kd0uktg6.jpg", "http://ww1.sinaimg.cn/large/679865b1gw1ehrlf1b3wxj20uk0kdgqb.jpg",  "http://ww3.sinaimg.cn/large/679865b1gw1ehrlezufszj20uk0kd7bh.jpg", "http://ww4.sinaimg.cn/large/679865b1gw1ehrleyz61dj20uk0kd794.jpg", "http://ww4.sinaimg.cn/large/679865b1gw1ehrleya5qaj20uk0kdgr1.jpg",

    ];

    var imgBox = document.getElementsByClassName('imgBox')[0];      //获取盒子
    var imgBoll = document.createElement('div');            //创建一个图片导航点
    var imgBoxWidth = imgBox.offsetWidth;   //盒子宽度
    var img = [];                //所有图片
    var imgIndex = 0;           //当前显示的图片下标
    var isRotate = false;       //防止多个定时器同时执行
    var timer;
    createLabel();      //创建标签
    init();             //初始化

    function createLabel() {
        for (var i = 0; i < img4.length; i++) {
            img.push({
                img: document.createElement('img'),
                boll: document.createElement('div'),
                src: img4[i],
                a: document.createElement('a'),
                herf: "javascript:void(0);"
            });
            img[img.length - 1].img.src = img[img.length - 1].src;          //设置图片来源
            img[img.length - 1].img.style.width = imgBoxWidth + 'px';       //图片大小和盒子一样大

            img[img.length - 1].a.style.top = '0px';                        //初始化位置      
            img[img.length - 1].a.style.left = imgBoxWidth * i + 'px';      //初始化位置

            img[img.length - 1].boll.className = "smallBoll"                //命名className
            img[img.length - 1].boll.style.bottom = '10%';              //下面间隔
            img[img.length - 1].boll.style.left = (imgBoxWidth - 20 * img4.length) / 2 + i * 20 + 'px';         //中间对齐
            img[img.length - 1].boll.onclick = function () {            //绑定点击
                if (isRotate) {
                    return;
                }
                img[imgIndex].boll.className = "smallBoll";
                this.className = "selectBoll";
                var thatIndex;
                //找到当前的下标
                for (var i = 0; i < img.length; i++) {
                    if (this == img[i].boll) {
                        thatIndex = i;
                        break;
                    }
                }
                if (thatIndex > imgIndex) {
                    var step = thatIndex - imgIndex;
                    var timer = setInterval(function () {
                        nextImg(step * 10);         //距离越远切换越快
                        if (thatIndex == imgIndex + 1) {
                            clearInterval(timer);
                            return;
                        }
                    }, 1);
                }
                else if (thatIndex < imgIndex) {
                    var step = imgIndex - thatIndex;
                    var timer = setInterval(function () {
                        preImg(step * 10);
                        if (thatIndex == imgIndex - 1) {
                            clearInterval(timer);
                            return;
                        }
                    }, 1);
                }
            }
            //插入
            imgBoll.appendChild(img[img.length - 1].boll);
            img[img.length - 1].a.appendChild(img[img.length - 1].img);     //图片插入到a标签中
            imgBox.appendChild(img[img.length - 1].a);                      //a标签插入到盒子中
        }
    }
    function init() {
        imgBoll.className = 'imgbollBox';
        imgBox.appendChild(imgBoll);
        img[imgIndex].boll.className = "selectBoll";
        img[0].img.onload = function () {       //第一张图片加载完成
            imgBox.style.height = img[0].img.offsetHeight + 'px';       //调整盒子大小为第一张图片的大小
            var preImgButton = document.getElementsByClassName('preImg')[0];
            var nextImgButton = document.getElementsByClassName('nextImg')[0];
            nextImgButton.style.height = img[0].img.offsetHeight + 'px';
            nextImgButton.onclick = function () { nextImg() };          //绑定点击
            document.getElementsByClassName('nextImgShell')[0].style.height = img[0].img.offsetHeight + 'px';
            preImgButton.style.height = img[0].img.offsetHeight + 'px';
            preImgButton.onclick = function () { preImg() };
            document.getElementsByClassName('preImgShell')[0].style.height = img[0].img.offsetHeight + 'px';
            timer = setInterval(function () {
                nextImg();
            }, 3000);
        }
        imgBox.onmouseover = function () {          //鼠标放在图片上不自动滑动图片
            clearInterval(timer);
        }
        imgBox.onmouseout = function () {           //离开图片重新开始滑动图片
            timer = setInterval(function () {
                nextImg();
            }, 3000);
        }
    }




    function nextImg(setStep) {
        if (isRotate) {
            return;
        }
        isRotate = true;
        var that = imgIndex % img.length;           //当前图片
        var next = (imgIndex + 1) % img.length;     //下一张图片
        img[that].boll.className = "smallBoll";
        img[next].boll.className = "selectBoll";
        //将下一张图片移动到当前图片后,并一起滑动
        img[next].a.style.left = imgBox.offsetWidth + 'px';
        //滑动动画
        (function () {
            var step = setStep || 10;
            var count = 0;
            var timer = setInterval(function () {
                if (++count * step >= imgBoxWidth) {
                    img[that].a.style.left = -imgBoxWidth + 'px';       //对齐盒子
                    img[next].a.style.left = '0px';
                    clearInterval(timer);
                    imgIndex = next;
                    isRotate = false;
                    return;
                }
                img[next].a.style.left = img[next].a.offsetLeft - step + 'px';
                img[that].a.style.left = img[that].a.offsetLeft - step + 'px';
            }, 1);
        }());
    }

    function preImg(setStep) {
        if (isRotate) {
            return;
        }
        isRotate = true;
        var that = imgIndex % img.length;           //当前图片
        var pre = (imgIndex + img.length - 1) % img.length;     //下一张图片
        img[that].boll.className = "smallBoll";
        img[pre].boll.className = "selectBoll";
        //将上一张图片移动到当前图片前,并一起滑动
        img[pre].a.style.left = -imgBox.offsetWidth + 'px';
        //滑动动画
        (function () {
            var step = setStep || 10;
            var count = 0;
            var timer = setInterval(function () {
                if (++count * step >= imgBoxWidth) {
                    img[that].a.style.left = imgBoxWidth + 'px';       //对齐盒子
                    img[pre].a.style.left = '0px';
                    clearInterval(timer);
                    imgIndex = pre;
                    isRotate = false;
                    return;
                }
                img[pre].a.style.left = img[pre].a.offsetLeft + step + 'px';
                img[that].a.style.left = img[that].a.offsetLeft + step + 'px';
            }, 1);
        }());
    }
}());

css:

* {
    margin: 0px;
    padding: 0px;
}

.imgBox {
    width: 800px;
    overflow: hidden;
    position: relative;
}

.imgBox a {
    position: absolute;
}

.smallBoll, .selectBoll {
    width: 12px;
    height: 12px;
    position: absolute;
    background: #eee;
    user-select: none;
    border-radius: 50%;
    opacity: 0.618;
}

div.selectBoll {
    background: rgb(0, 255, 0);
}

.preImgShell, .nextImgShell {
    width: 60px;
    user-select: none;
    position: absolute;
    z-index: 8888;
}

.preImgShell {
    left: 0px;
}

.nextImgShell {
    right: 0px;
}

.preImg, .nextImg {
    width: 80px;
    user-select: none;
    background: #eee;
    line-height: 50px;
    text-align: center;
    position: absolute;
    z-index: 9999;
    transition: all 0.5s;
}

.preImg {
    left: -80px;
    background: url() 100px 0px;
    background-size: 120px 200px;
    background-position: center;
    background-repeat: no-repeat;
}

.nextImg {
    right: -80px;
    background: url() 100px 0px;
    background-size: 120px 200px;
    background-position: center;
    background-repeat: no-repeat;
}

.preImgShell:hover .preImg {
    left: 0px;
}

.nextImgShell:hover .nextImg {
    right: 0px;
}

 

html:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <link rel="stylesheet" href="imgRotate.css">
</head>

<body>
    <div class="imgBox">
        <div class="preImgShell">
            <div class="preImg"></div>
        </div>
        <div class="nextImgShell">
            <div class="nextImg"></div>
        </div>
    </div>

</body>
<script src="imgRotate.js"></script>

</html>

 

posted @ 2018-08-22 12:15  oleolema  阅读(2569)  评论(3编辑  收藏  举报