jQuery实现轮播

题目1:轮播的实现原理是怎样的?如果让你来实现,你会抽象出哪些函数(or接口)供使用?(比如 play())

轮播原理.jpg
布局:

设置一个整体轮播容器,给容器设置一个图片的宽高,设置相对定位,并且设置overflow:hide 隐藏溢出部分。轮播容器内创建图片容器和焦点切换容器,设置图片容器,高度为图片高度,宽度为所有包含的图片宽度(可以不设置宽度,但需要使用jQ添加计算后的所有图片宽度),把所有图片排成一列,便于实现轮播。设置一个焦点选项区域,相对于轮播容器定位在底部。

逻辑:

通过移动内容块的位置,使内容块内部的元素达到切换效果,具体实现为:在尾部clone第一个元素,在头部clone最后一个元素并相应增加图片容器的宽度;当运动到clone首图片时,立即移动到真实首图片,当运动到clone尾图片时,就立即将其移动到真实尾图片,这样我们的肉眼看上去就是连贯循环的。当快速切换到不同页面时就需要知道当前正在展现的是哪一页,可以设置一个标记位,初始值为0,每次切换时这个标记位的值都要跟着改变。

函数接口:
  • autoPlay() 自动轮播
  • playNext() 切换到下一页
  • playPre() 切换到上一页
  • setBullet() 设置焦点切换效果

题目2:实现视频中的左右滚动无限循环轮播效果

css部分

  .carousel{
      position: relative;
      width: 320px;
      height: 180px;
      overflow: hidden;
  }
  .carousel ul,
  .carousel li{
      margin: 0;
      padding: 0;
      list-style: none;
  }
  .carousel .img-ct{
      position: absolute;
      overflow: hidden;
  }
  .carousel .img-ct>li{
      float: left;
  }
  .carousel .img-ct img{
      width: 320px;
      height: 180px;
  }
  .carousel .arrow{
      position: absolute;
      top: 50%;
      margin-top: -15px;
      display: inline-block;
      width: 30px;
      height: 30px;
      border-radius: 50%;
      border: 1px solid #fff;
      line-height: 30px;
      color: #fff;
      text-align: center;
      text-decoration: none;
  }
  .carousel .arrow:hover{
      opacity: 0.8;
  }
  .carousel .pre{
      left: 10px;
  }
  .carousel .next{
      right: 10px;
  }
  .carousel .bullets{
      position: absolute;
      bottom: 10px;
      font-size: 0;
      width: 100%;
      z-index: 1;
      text-align: center;
  }
  .carousel .bullets > li{
      display: inline-block;
      width: 30px;
      height: 5px;
      border: 1px solid #ccc;
      border-radius: 4px;
      cursor: pointer;
      margin: 0 3px;
  }
  .carousel .bullets > li.active{
      background-color: #ccc;
  }

HTML部分

<div class="carousel">
    <ul class="img-ct">
        <li data-id=0>
            <a href="#">
                ![](http://upload-images.jianshu.io/upload_images/6005909-86f49e432575d271.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
            </a>
        </li>
        <li data-id=1>
            <a href="#">
                ![](http://upload-images.jianshu.io/upload_images/6005909-ddd21ffff5534f31.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
            </a>
        </li>
        <li data-id=2>
            <a href="#">
                ![](http://upload-images.jianshu.io/upload_images/6005909-b6b9c506d210731d.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
            </a>
        </li>
        <li data-id=3>
            <a href="#">
                ![](http://upload-images.jianshu.io/upload_images/6005909-81c5c7a40d5083e7.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
            </a>
        </li>
    </ul>
    <a href="#" class="pre arrow"><</a>
    <a href="#" class="next arrow">></a>
    <ul class="bullets">
        <li class="active"></li>
        <li></li>
        <li></li>
        <li></li>
    </ul>
</div>

jQuery部分

var $imgCt = $('.carousel .img-ct')
//获取图片容器
var $imgs = $('.carousel .img-ct>li')
//获取所有图片
var $preBtn = $('.carousel .pre')
//获取上一页按钮
var $nextBtn = $('.carousel .next')
//获取下一页按钮
var $bullets = $('.carousel .bullets li')
//获取所有焦点

var pageIndex = 0;
//当前图片下标
var isAnimate = false
//防止用户的重复点击,加锁
var imgCount = $imgs.length
//获取所有图片长度
var imgWidth = $imgs.width()
//获取单个图片宽度
$imgCt.append($imgs.first().clone())
//克隆第一个图片,添加到图片容器最后
$imgCt.prepend($imgs.last().clone())
//克隆最后一个图片,添加到图片容器最前
$imgCt.width(( imgCount + 2 ) * imgWidth )
//把图片容器的宽度,设置为([原始图片个数+后来新增的2个] x 一个图片宽度)
$imgCt.css({left:-imgWidth})
//图片容器向左移动负一个图片宽度(整体左移一个图片位置)
$nextBtn.click(function(){
    playNext(1) //点击下一张按钮,执行函数 展示 下一页
})
$preBtn.click(function(){
    playPre(1) //点击上一张按钮,执行函数 展示 上一页
})

/*点击焦点定位部分*/
$bullets.click(function(){
    var index = $(this).index()  //获取点击焦点下标
    if( index > pageIndex ){ //如果点击的下标大于当前图片的下标
    playNext( index - pageIndex )  //调用下一页函数(滚动格数为: [点击下标 - 当前图片的下标位置])
    }else if(index < pageIndex){    //如果点击的下标 小于 当前图片的下标位置
        playPre( pageIndex - index )  //调用向前滚动函数(滚动格数为: [当前图片的下标位置 - 点击下标])
    }
})

function playNext(len){
    if(isAnimate) return;  //正在动画中,return掉
    isAnimate = true ;  //表示现在要动画了 加锁
    $imgCt.animate({
        left: '-=' + len * imgWidth //在原来基础上,再减少 len 个图片宽度的值
    },function(){   //当执行完之后
        pageIndex += len; //一次加上滚动的页码
        if( pageIndex === imgCount ){   //当点击到[原始图片个数](4)
            pageIndex = 0;
            $imgCt.css({left:-imgWidth})    //回到初始位置
        }  //这里用.css 没有动画效果,立刻切换到
        setBullet() //调用焦点切换函数
        isAnimate = false;  //动画完成之后 解锁
    })
}
function playPre(len){
    $imgCt.animate({
        left:'+='+len*imgWidth  //在原来基础上,再加上 len 个图片宽度的值
    },function(){
        pageIndex -= len  //一次减去滚动的页码
        if(pageIndex < 0){  //当滚动到最前一张
            pageIndex = imgCount - 1  //总数-1(3) 切换到最后一张
            $imgCt.css({left:-imgCount*imgWidth})
        }  //让图片切换过去
        setBullet()   //调用焦点切换函数
    })
}

function setBullet(){
    $bullets.removeClass('active')  //全部去掉.active
            .eq(pageIndex)  //点击的那个
            .addClass('active') //添加.active
}

//自动轮播部分
// setInterval(function(){
//     playNext(1)
// },3000)
我的代码

题目3:实现一个渐变轮播效果, 效果范例444

我的代码
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容