jQuery实现轮播图(一)

廉价感情. 提交于 2019-12-01 11:21:53

轮播概念图
这里写图片描述

这里的轮播图的轮播方式是自动每隔一段时间向左移动一张图,循环滚动(还有变换透明度来实现轮播的)

轮播图的原理很简单:设置一个div(box),给其相对定位并且overflow:hidden超出box的范围隐藏,里面包含一个ul,给其绝对定位,ul里面有多个li(li里面存放着轮播的图片,给li左浮动实现左右轮播效果)。每隔一段时间让ul向左移动一个li的width距离,这样图片就一张一张的移动了,实现了基本的自动轮播功能

如果要实现无限滚动的功能我们就需要在上述多个li的后面再添加一个li,其里面的图片和第一张一样,当ul一直向左运动到box中显示最后一个li时(这里的图片是第一张),让ul的margin-left为0px(还原到最初位置),虽然页面元素执行了一个动态的变换,但是用户却看不到变化。这样用户看到的只是一个无限轮播变换。
这里写图片描述


在无限轮播的基础上加上左右点击滑动按钮,和轮播导航点击圆点,便实现了一个基本功能的轮播图
这里写图片描述

 $(".ul_list").stop().animate({"marginLeft":-700*num+"px"},580);

代码中有一个.stop()事件,是用来消除当用户快速的反复来回点击两个不同圆点或者左右按钮时图片来回变动bug

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <script src="js/jquery-2.2.0.min.js"></script>
</head>
<style>
    *{
        margin: 0;
        padding: 0;
    }
    #box{
        width: 700px;
        height: 400px;
        border: 1px solid #102327;
        position: relative;
        margin:0 auto;
        margin-top: 100px;
        overflow: hidden;
    }
    .ul_list{
        width:3500px;
        height: 400px;
        position: absolute;
    }
    .li_list{
        width: 700px;
        height: 400px;
        list-style: none;
        float: left;
    }
    .li_list img{
        width: 100%;
        height: 100%;
    }
    .odiv_nav{
        position: absolute;
        bottom: 20px;
        left: 50%;
        margin-left: -100px;
    }
    .span_list{
        width: 20px;
        height: 20px;
        border: 3px solid white;
        border-radius:50%;
        float: left;
        margin-left: 20px;
        cursor: pointer;
    }
    .left_click{
        position: absolute;
        width: 80px;
        height: 400px;
        font-size:4em;
        color: white;
        text-align: center;
        line-height: 400px;
        cursor: pointer;
        z-10000;
    }
    .right_click{
        position: absolute;
        right: 0px;
        width: 80px;
        height: 400px;
        font-size:4em;
        color: white;
        text-align: center;
        line-height: 400px;
        cursor: pointer;
        z-10000;
    }
    .btn_left{
        position: absolute;
        left: -40px;
        width: 40px;
        height: 400px;
        opacity: 0.5;
        z-index: 9999;
        box-shadow:40px 0px 150px white;
        transition: all 0.2s;
    }

    .btn_right{
        position: absolute;
        right: -40px;
        width: 40px;
        height: 400px;
        font-size: 4em;
        box-shadow:-40px 0px 150px white;
        opacity: 0.5;
        z-index: 9999;
        transition: all 0.2s;
    }
</style>
<body>
<div id="box">
    <ul class="ul_list">
        <li class="li_list"><img src="images/1.jpg" alt=""/></li>
        <li class="li_list"><img src="images/2.jpg" alt=""/></li>
        <li class="li_list"><img src="images/3.jpg" alt=""/></li>
        <li class="li_list"><img src="images/4.jpg" alt=""/></li>
        <li class="li_list"><img src="images/1.jpg" alt=""/></li>
    </ul>
    <div class="odiv_nav">
        <span class="span_list"></span>
        <span class="span_list"></span>
        <span class="span_list"></span>
        <span class="span_list"></span>
    </div>
    <div class="left_click"><</div>
    <div class="right_click">></div>
    <div class="btn_left"></div>
    <div class="btn_right"></div>
</div>
<script>
    $(function(){
        var num=0;
        var timer=null;
        go();
        $("#box").mouseenter(function(){//实现当鼠标移动到box上时,不执行自动轮播功能
            clearInterval(timer);//移动进去时清除定时器
        }).mouseleave(function(){
            go();//移出后执行go函数
        });
        $(".span_list").eq(0).css("backgroundColor","white");
        //页面加载后默认是第一张图,则让第一个导航圆点变为“选中色”。
        function go(){
          timer=setInterval(function(){//设置定时器
                num++;//用一个全局变量来控制图的运动次数
                if(num>4){//如果移动到了最后一张图,则num赋值1,调整ul边距(相当于初始化)
                    num=1;
                    $(".ul_list").css("margin-left","0px");
                }
                if(num==4){//由于圆点只有四个,而图片有五张,当移动到第五张图片时,给第一个圆点“选中色”。
                    $(".span_list").css("backgroundColor","transparent");
                    $(".span_list").eq(0).css("backgroundColor","white");
                }
                else{//图片运动一次,导航圆点也动态的变换,这里先让所有圆点变为“不选中色”,再让当前圆点变为“选中色”。
                    $(".span_list").css("backgroundColor","transparent");
                    $(".span_list").eq(num).css("backgroundColor","white");
                }
                $(".ul_list").animate({"marginLeft":-700*num+"px"},580);//使用animate实行运动功能
            },2000);
        }

        $(".span_list").each(function (index) {//遍历每一个圆点添加点击事件,点击当前圆点则让num值赋为当前圆点的索引
            $(this).click(function () {
                num=index;
                $(".span_list").css("backgroundColor","transparent");
                $(".span_list").eq(num).css("backgroundColor","white");
                $(".ul_list").stop().animate({"marginLeft":-700*num+"px"},580);
            })
        });

        $(".right_click").click(function(){
        //右按钮点击事件,每点击一次num++,这里有很多的判断,是用来消除一些BUG的。
            if(num<=4){num++;}
            if(num>4){
                num=1;
                $(".ul_list").css("margin-left","0px");
            }
            if(num==4){
                $(".span_list").css("backgroundColor","transparent");
                $(".span_list").eq(0).css("backgroundColor","white");
            }
            else{
                $(".span_list").css("backgroundColor","transparent");
                $(".span_list").eq(num).css("backgroundColor","white");
            }
            $(".ul_list").stop().animate({"marginLeft":-700*num+"px"},580);

        });

        $(".left_click").click(function(){//左按钮点击事件
            if(num>=0){num--;}
            if(num<0){
                num=3;
                $(".ul_list").css("margin-left","-2800px")
                $(".span_list").css("backgroundColor","transparent");
                $(".span_list").eq(3).css("backgroundColor","white");
            }
            else{
                $(".span_list").css("backgroundColor","transparent");
                $(".span_list").eq(num).css("backgroundColor","white");
            }
            $(".ul_list").stop().animate({"marginLeft":-700*num+"px"},580);

        });


        $(".left_click").hover(function(){//这里是实现左右按钮的阴影效果显示,用到了hover事件
            $(".btn_left").css("opacity","1");
        },function(){
            $(".btn_left").css("opacity","0.5");
        });

        $(".right_click").hover(function(){
            $(".btn_right").css("opacity","1");
        },function(){
            $(".btn_right").css("opacity","0.5");
        });

    });
</script>
</body>
</html>
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!