自己实现PC端jQuery版轮播图

最近其他项目不是很忙,被安排给公司的官网项目做一个新的页面(之前没接触公司官网项目),其中有一个用到轮播图的地方,最开始想直接用swiper.js插件实现就好了,可是发现官网项目里之前都没有引入过swiper.js,后来想了想,就不引入它了,免得又得增加依次一次网络请求,项目里既然已经用到了jQuery,那就索性用jQuery写一个轮播图吧。

现在把自己写的轮播图这块代码单独拿出来,做一个小demo写在这里记录一下(demo中轮播图的图片网上随意找的)

实现的效果:

    1、自动轮播(轮播时间间隔在js代码中自定义)

    2、点击左右侧按钮,实现手动切换

    3、底部小圆点根据切换图片的位置相应的显示active状态

    4、鼠标经过轮播图区域,停止轮播,离开轮播图区域开始轮播

代码目录结果如下:

一、index.html

注:这里以5张图片为例,页面上真正轮播展示给用户看到的是5张不同的图片,但是为了轮播效果的连贯性,所以在第一张图片前面添加上第五张图片,在第五张图片后面加上了第一张图片,所以demo结构里是7张图片,每张图片的尺寸必须都是一样的哦(这里宽高尺寸是720*350px)。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>PC-jquery版轮播图</title>
    <link rel="stylesheet" href="css/style.css">
</head>
<body>
<div class="layout">
    <h2 style="text-align: center;">PC-jquery版轮播图</h2>
    <div class="slide" id="slide">
        <div id="outer" class="outer">
            <ul id="inner" class="inner">
                <li><a href="http://www.baidu.com"><p>图片-5</p><img src="images/slide-5.jpg"></a></li>
                <li><a href="http://www.baidu.com"><p>图片-1</p><img src="images/slide-1.jpg"></a></li>
                <li><a href="http://www.baidu.com"><p>图片-2</p><img src="images/slide-2.jpg"></a></li>
                <li><a href="http://www.baidu.com"><p>图片-3</p><img src="images/slide-3.jpg"></a></li>
                <li><a href="http://www.baidu.com"><p>图片-4</p><img src="images/slide-4.jpg"></a></li>
                <li><a href="http://www.baidu.com"><p>图片-5</p><img src="images/slide-5.jpg"></a></li>
                <li><a href="http://www.baidu.com"><p>图片-1</p><img src="images/slide-1.jpg"></a></li>
            </ul>

       <!--底部小圆点-->
            <ol class="dot" id="dot">
                <li class="active"></li>
                <li></li>
                <li></li>
                <li></li>
                <li></li>
            </ol>
        </div>
     <!--左右两侧的点击切换按钮-->
        <div class="arrow-box">
            <div class="arrow arrow-l" id="arrow_l">‹</div>
            <div class="arrow arrow-r" id="arrow_r">›</div>
        </div>
    </div>
</div>

<script src="js/jquery.min.js"></script>
<script src="js/index.js"></script>
</body>
</html>

二、style.css

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
.layout {
    width: 1000px;
    margin: 30px auto;
}
ul,ol,li {
    list-style: none;
}
.slide {
    position: relative;
    width: 900px;
    margin:auto;
}
.slide .outer {
    position: relative;
    margin: 30px auto;
    width: 720px;
    height: 400px;
    overflow: hidden;
}
.slide .outer .inner {
    width: 5040px;
    height: 350px;
    position: absolute;
    left: -720px;
    top: 0;
}
.slide .outer .inner li {
    float: left;
    height: 350px;
}
.slide .outer .inner li a {
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
}
.slide .outer .inner li a p {
    position: absolute;
    left: 0;
    bottom: 0;
    color: #fff;
    font-size: 18px;
    width: 720px;
    height: 80px;
    line-height: 80px;
    padding-left: 50px;
    background: linear-gradient(180deg,rgba(0,0,0,0), rgba(0,0,0,0.5));
}
.slide .outer .dot {
    margin-top: 365px;
    text-align: center;
}
.slide .outer .dot li {
    height: 6px;
    width: 6px;
    border-radius: 3px;
    background-color: #d2cbcb;
    display: inline-block;
    margin: 0 3px;
}
.slide .outer .dot li.active {
    background-color: #6e5ca5;
}
.slide .arrow-box {
    position: absolute;
    width: 900px;
    height: 60px;
    top: 150px;
    left: 0;
}
.slide .arrow-box .arrow {
    width: 60px;
    height: 60px;
    line-height: 60px;
    text-align: center;
    border-radius: 30px;
    background-color: #dde2e6;
    font-size: 60px;
    color: #999;
    cursor: pointer;
}
.slide .arrow-box .arrow.arrow-l {
    float: left;
}
.slide .arrow-box .arrow.arrow-r {
    float: right;
}

三、index.js

注:js代码中,每个变量均已给了注释。为了防止快速多次点击,而出现动画不停的现象,这里在每次切换图片的时候先调用stop(false,true)。但是注意在向左侧滚动的时候,滚动到最后一张图图片后,再次切换时就不要用stop(false,true),而是要瞬间定位到第一张图片(其实是dom结构中的第二张)的位置,同样,向右侧滚动时,当滚动到第一张图片后,再次切换时就不用stop(false,true),而是要瞬间定位到最后一张图片(其实是dom结构中的倒数第二张)的位置

var interval = 3000;                //轮播间隔时间
var arrowL = $('#arrow_l');         //左侧箭头
var arrowR = $('#arrow_r');         //右侧箭头

var slideBox = $('#slide');         //轮播图区域
var innerBox = $('#inner');         //内层大盒子
var img = innerBox.children('li');  //每个图片
var dot = $('#dot');                //小圆点盒子

var imgW = $(img[0]).outerWidth();  //每个li标签的宽度

var imgCount = 5;                   //总图片个数(不同图片的个数)(实际dom上是有7张)
var i = 0;                          //初始化为第0张图片
timer = null;                       //定时器

//自动轮播
timer = setInterval(function () {
    i++;
    innerBox.stop(false, true).animate({'left':-i*imgW+'px'},300)
    dot.find('li').removeClass('active').eq(i-1).addClass('active')
    if(i > imgCount){
        innerBox.animate({'left':-1*imgW+'px'},0);
        dot.find('li').removeClass('active').eq(0).addClass('active')
        i = 1;
    }
},interval)

//点击右侧箭头,播放下一张
arrowR.click(function () {
    i++;
    innerBox.stop(false, true).animate({'left':-i*imgW+'px'},300)
    dot.find('li').removeClass('active').eq(i-1).addClass('active')
    if(i > imgCount){
        innerBox.animate({'left':-1*imgW+'px'},0);
        dot.find('li').removeClass('active').eq(0).addClass('active')
        i = 1;
    }
})

//点击左侧箭头,播放上一张
arrowL.click(function () {
    i--;
    innerBox.stop(false, true).animate({'left':-i*imgW+'px'},300)
    dot.find('li').removeClass('active').eq(i-1).addClass('active')
    if(i < 1){
        innerBox.animate({'left':-imgCount*imgW+'px'},0);
        dot.find('li').removeClass('active').eq(imgCount-1).addClass('active')
        i = imgCount;
    }
})

//鼠标经过轮播图区域时,清除定时器,停止自动轮播
slideBox.mouseenter(function () {
    clearInterval(timer);
})

//鼠标离开轮播图区域时,重新启动自动轮播
slideBox.mouseleave(function () {
    timer = setInterval(function () {
        i++;
        innerBox.stop(false, true).animate({'left':-i*imgW+'px'},300)
        dot.find('li').removeClass('active').eq(i-1).addClass('active')
        if(i > imgCount){
            innerBox.animate({'left':-1*imgW+'px'},0);
            dot.find('li').removeClass('active').eq(0).addClass('active')
            i = 1;
        }
    },interval)
})

四、效果图展示

 注:毕竟是自己写的,多少可能还会存在一些问题,如果有发现问题的,欢迎及时指出来哦。

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

发表于

我来说两句

1 条评论
登录 后参与评论

相关文章

来自专栏Golang语言社区

golang的HTTP基本认证机制实例详解

看了<<http权威指南>>第12章HTTP基本认证机制(本站下载地址:http://www.jb51.net/books/93254.html),感觉讲的蛮详...

5426
来自专栏移动端开发

Android学习--持久化(三) SQLite & LitePal

    自己做为一个iOS开发,看到安卓这一块的时候,那中浓烈的熟悉味道更加强烈,SQLite这种轻量级的关系型数据库的使用在移动端相差不多,iOS有FMDB,...

863
来自专栏Flutter入门到实战

模仿安卓源码,手写过时的方法兼容低版本

我们经常会使用getColor(R.color.XXX)获取颜色的资源文件,但是在安卓6.0开始,这个方法被标注为过时,推荐使用两个参数的方法替代,如下图所示:

492
来自专栏Android干货园

Android高仿微信照片选择器+预览+显示照片

版权声明:本文为博主原创文章,转载请标明出处。 https://blog.csdn.net/lyhhj/article/details/49...

562
来自专栏青蛙要fly的专栏

项目需求讨论-Retrofit中文提交及上传头像功能

很早就开通了掘金上发表文章权限,但一直没有在掘金上写,都是在简书上面写好,然后偷懒在掘金上直接就网址分享链接。O(∩_∩)O~这次就上来写了。

763
来自专栏蜉蝣禅修之道

Android Studio2.2下NDK开发初试

1455
来自专栏上善若水

025android初级篇之Android am命令的实现

am命令一个重要的调试工具,主要功能包括如下: 启动停止Activity Service,启动Broadcast, 查看管理这些信息。

1516
来自专栏7号代码

Android应用界面开发——Widget(实现液晶时钟)

桌面控件是通过BroadcastReceiver的形式进行控制的,因此每个桌面控件都对应于一个BroadcastReceiver。开发桌面控件时,只需继承Bro...

1226
来自专栏DannyHoo的专栏

利用UIPanGestureRecognizer手势全屏侧滑返回

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u010105969/article/details/...

742
来自专栏林冠宏的技术文章

记一次使用 android 自带 WebView 做富文本编辑器之API、机型的兼容及各种奇葩bug的解决

转载请声明出处(https://cloud.tencent.com/developer/user/1148436/activities) 目录 1,测试设备介绍...

48010

扫码关注云+社区