轮播图案例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>轮播图4</title>
    <style>
        *{
            margin: 0;
            padding: 0;
            list-style: none;
        }
        .box {
            overflow: hidden;
            position: relative;
        }
        img {
            width: 640px;
            height: 400px;

        }
        ol {
            width: 30000px;
            position: absolute;
        }
        ol li{
            float: left;
        }
        .box{
            width: 640px;
            height: 400px;
            border: orange 2px solid;
        }
        #btn{

            position:absolute;
            right: 10px;
            bottom: 10px;
        }
        #btn li {
            width: 20px;
            height: 20px;
            line-height: 20px;
            text-align: center;
            color: white;
            display: inline-block;
            border: 1px solid deepskyblue;
            margin-right: 5px;
            cursor: pointer;
        }
        .foc{
            background-color: coral;
        }
        .arr {
            width: 640px;
            height: 400px;
            position: absolute;
            top: 0;
            /*display: block;*/
        }
        .arr span {
            width: 50px;
            height: 80px;
            background-color: rgba(255,255,255,0.3);
            color: #E2D762;
            position: absolute;
            top: 50%;
            margin-top: -40px;
            line-height: 80px;
            font-size: 20px;
            font-weight: bold;
            text-align: center;
            z-index: 65151;
            cursor: pointer;
            border-radius: 0 8px 8px 0;
        }
        #right{
            right: 0;
            border-radius: 8px 0 0  8px;

        }
    </style>
</head>
<body>
<div class="box" id="box">
    <div class = "arr">
        <span id = "left"> < </span>
        <span id= "right"> > </span>
    </div>
    <ol class = "pic">
        <li><a href="#"><img src="../images/1.jpg" alt=""></a></li>
        <li><a href="#"><img src="../images/2.jpg" alt=""></a></li>
        <li><a href="#"><img src="../images/3.jpg" alt=""></a></li>
        <li><a href="#"><img src="../images/4.jpg" alt=""></a></li>
        <li><a href="#"><img src="../images/5.jpg" alt=""></a></li>
    </ol>
    <ul id="btn">
        <!--这里放小按钮-->
    </ul>

</div>

<script>
    var box = document.getElementById("box");
    var pic = document.getElementsByClassName("pic")[0];
    var imgW = document.getElementsByTagName("img")[0].width;
    var list = pic.children;
    var btn = document.getElementById("btn");
    var arr = document.getElementsByClassName("arr")[0];
    var left = arr.firstElementChild;
    var right  = arr.lastElementChild;
    //引入移动的函数
    function move(element,target){
        clearInterval(timeId);    //解决隐藏的BUG,每次点击先清理定时器再创建定时器,解决多次点击时运动变快的BUG
        var current = element.offsetLeft;
        var timeId = setInterval(function(){
            if (current != target) {
                var temp = 9;    //设置每次走的距离    这句代码放进计时器中才能实现往回走,即current>target的情况。因为这种情况每次计时都要设置temp = -10,不放进来的话temp会10,-10来回变,导致盒子抖动不能到达目标地
                temp = current <= target ? temp : -temp;    //根据当前和目标的关系确定往哪走
                if (Math.abs(current-target) > Math.abs(temp)) {    //当前距离大于每次走得距离则继续走
                    current += temp;
                    element.style.left = current + "px";
                } else {        //当前距离小于等于每次走得距离:则直接跳到目标位置,并且清理定时器
                    element.style.left = target + "px";
                    clearInterval(timeId);
                }
            }

        },1);
    }

    //创造小按钮
    for (var i = 0; i < list.length; i++) {
        var li = document.createElement("li");
        btn.appendChild(li);
        li.innerText = i+1;
        li.setAttribute("index",i);//设置一个自定义属性
        btn.firstElementChild.className = "foc";//设置初始第一个按钮的样式

        //创造的同时注册鼠标进入事件
        var index = 0;  //全局变量
        li.onmouseover = function () {
            for (var j = 0; j < btn.children.length; j++) {
                btn.children[j].className = "";//清除所有按钮的样式
                this.className = "foc"; //设置当前按钮的样式
            }
            index = this.getAttribute("index");
            move(pic, -index*imgW);
        };
    }


    //制作左右点击的部分
    //设置鼠标进入离开
    box.onmouseover = function(){
        arr.style.display = "block";
    };
    box.addEventListener("mouseout",function(){
        arr.style.display = "none";
    },false)

    pic.appendChild(list[0].cloneNode(true));//克隆第一个图放到最后
    //设置 鼠标点击事件
    right.onclick = rightMove;

    function rightMove(){

         console.log(index);

        //设置图片的运动
        if(index == list.length-1){ //当到达克隆的那一张再点击时,
            index = 0;  //索引复原
            pic.style.left = 0+"px";//立即跳到第一张
        }

            index ++; //将索引加一即下一个小按钮对应的索引。这里调用了上个函数内的变量,必须将这个变量设置为全局变量才能得到
            move(pic, -index*imgW);//这两句放在if的外面,每次点击都会做的事

        //设置小按钮的样式变化
        if(index == list.length-1 ){    //当到达克隆的图时,应该把第一个小按钮设置上
            for (var j = 0; j < btn.children.length; j++) {
                btn.children[j].className = "";//清除所有按钮的样式
                btn.children[0].className = "foc"; //设置第一个按钮的样式
            }
        }else{
            for (var j = 0; j < btn.children.length; j++) {
                btn.children[j].className = "";//清除所有按钮的样式
                btn.children[index].className = "foc"; //设置当前按钮的样式
            }
        }
       // 特别注意:由于小按钮个数和图片个数不同,导致利用索引设置小按钮样式时会出现BUG,
        // 即索引值加到length-1时已经无法设置这个对应的小按钮(这个小按钮不存在)所以设置按钮样式的代码和设置图片移动的代码应分开
        //克隆的加入,最后一张伪图的加入导致这里很绕,索引值与图片的对应关系变化,索引值与小按钮的对应变化应注意
    };
    left.onclick = function () {
        console.log(index);
        if(index == 0){ //在第一张时点击
            index = list.length-1;  //索引到最大
            pic.style.left = -index*imgW+"px";//立即跳到clone的那张图
        }
        index --;
        move(pic, -index*imgW);

            for (var j = 0; j < btn.children.length; j++) {
                btn.children[j].className = "";//清除所有按钮的样式
            }
            btn.children[index].className = "foc"; //设置当前按钮的样式,这句放在for外面更好,只执行一次,放在for里会执行多次
        //这里的按钮样式设置不需要考虑特殊情况,因为这里的索引会--,索引与按钮会对应,而上面索引++时要考虑索引大于按钮的情况
    };

    //设置自动轮播
    //思路:利用定时器每隔一段时间执行一次点击有点按钮的事件


</script>
</body>
</html>

 

posted on 2018-09-21 21:11  临别一眼  阅读(261)  评论(1编辑  收藏  举报