在页面中写好结构和样式(根据情况而定)

 

外层用一个$(function(){})函数包裹起来,代表等页面的内容加载完成后再去执行jquery的功能代码。

 

获取到包裹ulli的大盒子元素:const $div = $('#div');和包裹图片的ul元素:$ul = $div.children('ul');再获取到包裹图片的每个li元素:$imgs = $ul.children();再获取到li的所有长度,因为后面我们要clone第一张到最后一张,所以不用具体的数字,为:const len = $imgs.length;此外还需再获取到一个li的宽度,为:const width = $imgs.eq(0).outerwidth()

 

需要声明两个变量记录下一张和上一张的状态,var index = 0

var lastindex = 0

 

此外,为了防止后面用户点得太快,轮播图出现bug,需要声明一个变量来记录轮播图的运动状态

var ismove = false(运动状态默认为false)、

 

开始做之前,我们需要知道一件事,就是当我们点到第五张的时候,如果直接跳回第一张,肯定会给到用户不好的体验,所以,此时,我们应该把第一张clone,放到最后一张后面,让两张相同的图片来进行跳转,这样其实我们是使用了一个障眼法来迷惑了用户。

$imgs.eq(0).clone().appendTo($ul)

 

把第一张克隆放到最后一张后,我们就紧接着去计算所有的li的长度。因为这时的长度,才是真正我们想要的长度。

$ul.width((len+1)*width)

 

其实这两句完全可以写为一句。

$ul.append($imgs.eq(0).clone()).width((len+1)*width)

 

以上的准备工作做好了之后,我们要开始创建下面的小按钮

  for(var i = 0; i

  $('

  • ').html(i+1).addclass(i === 0 ? 'ac' : '').appendTo('#div ol')

      }

    因为在css中写好了样式,创建好了之后会到之前写好的位置当中,i+1的意思是按钮的内容,会按12345…排列好,这也会让第一个小按钮默认为第一个,并具备ac这个样式。

     

    li创建好,并插入到(''#div ol')中后,这时我们要获取这元素

    const $btns = $('#div ol li')

     

    获取完成之后,要给他添加一个点击事件,让他能够点击切换

       $btns.on('click',function(){

       

       })

    添加好之后我们要开始在里面写内容了,还记得上面的ismove =false吗,其实每个事件都要加上这个代码,不过要进行判断,如果在动的时候,就停止下面的代码运行,停止的时候,就为true,让代码动起来。

    $btns.on('click',function(){

    ifismovereturn

    ismove = true

    })

    做好上一步之后,我们还要用之前声明的index = 0lastindex =0,来存储我们点击的时候的上一个和下一个的索引,这样就不用把五个事件都加进来清空了,

    $btns.on('click,function(){

    if(ismove) return;

    ismove =true;

    //可以把这一步理解为,把现任变成前任,

    //再给现任赋值他当前的索引

    lastindex = index;

    index = $(this).index()

    }')

    //接下来,我们要移出掉前任的“记忆”,把美好的“记忆”给现任

    $btns.on('click',function(){

    if(ismove) return

    ismove = true

    lastindex = index

    index = $(this).index()

    $btns.eq(lastindex).removeclass('ac')

    $btns.eq(index).addclass('ac')

    })

    接下来,我们既然已经控制好了点击的状态,不会让他暴躁,也获取了下一个和上一个li的索引,并给当前的li添加了’ac‘和上一个li移出’ac‘,那么接下来,就是让它动起来了!!!其实只需给它添加一个自定义动画函数即可~~~

       $btns.on('click',function(){

       if(ismove) return

       ismove = true

       lastindex = index

       index = $(this).index()

       $btns.eq(lastindex).removeclass('ac')

       $btns.eq(index).addclass('ac')

       $ul.animate({

       //这句代码表示,移动的距离是当前的索引值*width

       //因为是向左移动,所以,用-index,肯定有人问,为什么不在left前加符号,因为left是一个属性值

       left: -index * width

       }1000function(){

       ismove = false

       //这个是回调函数,是运动结束之后要去执行的代码,ismove = false,让本次运动结束,如果运动结束之后没什么事干,就可以不用写回调函数

       })

       })

    到此,我们下面的小图标的运动轮播图的切换就算完成了!!!

    接下来,我们要写的是向右点击的大箭头切换。
    其实上面也说了一些思路,这里我直接写一点

       $('#goNext').on('click',function(){ //XM http://www.xmchinese.com/

       if(ismove)  return

       ismove = true

       lastindex = index

       index++

       })

    上面的开头,看起来其实很熟悉,对吧,接下来,其实我们要做的就是点击的时候,当点到了最后一张,不是出现空白,而是让他跳转到第一张,并且下面的小按钮也跟着改变。

    $('#goNext').on('click',function(){

     

    if (ismove) return

     

    ismove = true

     

    lastindex = index

     

    index++

     

    if(index === len){

     

    index = 0

     

    //本次动画的意义在于,当移动到最后一张时,下标为len,让ul瞬间回到0的位置

     

    $ul.stop().animate({

     

    left = -len*width

     

    },1000,function(){

     

    //css'left',0)可以让它回到初始位置

     

    $ul.css('left',0)

     

    ismove = false

     

    })

     

    }else{

     

    $ul.stop().animate({

     

    left = -index*width;

     

    },1000,function(){

     

    ismove = false

     

    })

     

    }

     

    $btns.eq(lastindex).removeclass('ac')

     

    $btns.eq(index).addclass('ac')

     

    })

    接下来,我们需要做的是向左点击切换的大箭头
    其实向右点击,我们需要做的是,当点击到第一张之前时,要让它跳到最后一张:len - 1

       $('#goPrev').on('click',function(){

       if(ismove = false)

       ismove  = true

       lastindex = index

       index--

       //index小于0,即超出边界时,让index = len - 1

       if(index < 0){

       index = len - 1

       $ul.css('left',-len * width).animate({

       left = -index * width

       },1000,function(){

       ismove = false

       })

       }else{

       $ul.animate({

       left = -index*width

       },1000,function(){

       ismove = false

       })

       }

       $btns.eq(lastindex).removeclass('ac')

       $btns.eq(index).addclass('ac')

       })

    其实除了以上的东西,我们还要做的一个东西是,当鼠标移入时,这个轮播图停止,离开时继续自动播放。

       div1.hover(() => {

           clearInterval($div1.timer)

         }, (function auto () {

           $div1.timer = setInterval(() => {

             $('#goNext').trigger('click')

           }, 3000)

           return auto

         })())

       })

       

    到这里,我们的轮播图就算是完成了!!!