原生js实现一个简单的轮播图

想锻炼一下自己的原生js能力可以从写一个轮播图开始,轮播图的运用想必大家都知道吧,好了废话不多说,开始记笔记了,一些需要注意的点,我都在代码中标注了

首先是构造html:

<div id="container">
    <div id="list" style="left:-600px">
 <img src="img/4.jpg" alt="4">
<img src="img/1.jpg" alt="1">
<img src="img/2.jpg" alt="2">
<img src="img/3.jpg" alt="3">
<img src="img/4.jpg" alt="4">
<img src="img/1.jpg" alt="1">
    </div>
    <div id="buttons">
<span index=1 class="on"></span>
<span index=2></span>
<span index=3></span>
<span index=4></span>
    </div>
<a  id="prev" class="arrow"></a>
<a  id="next" class="arrow"></a>
</div>

这里需要讲一下的是图片本来是4个,但是需要把第4个和第一个分别多加入到第一个位置和最后一个位置,(为何要这一步?是为了实现无缝播放,由于移动时,为了让用户感觉到第4个图片播放完之后,是第一个图片,必须将第4个图片放到第一个图片的前面)并且设置list的偏移量为-600px(-600px是由于设置时将图片4放置在list的第一个位置,而要显示的是图片1,此时图片1的位置是-600px)

 然后设置css参数

*
        {
            margin: 0; 
            padding: 0; 
            text-decoration: none;
        }
        body
        {
            padding: 20px;
        }
        #container
        {   position: relative;
            overflow: hidden; 
            width: 500px; height: 500px; border: 3px solid rgb(247, 250, 203);
        }/*容器宽高为图片的宽度和高度*/
        #list
        {   position: absolute;
            z-index: 1;
            width: 3000px; /*list的所有图片数和图片的乘积*/
            height: 500px;
        }
        #list img
        {
            float: left;
            width: 500px;/*规定的图片的宽度*/
        }
        #buttons
        {
            position: absolute; 
            z-index: 2; 
            bottom: 20px; 
            left: 250px;
            width: 100px;
             height: 10px;
        }
        #buttons span
        {float: left; 
            width: 10px;
            height: 10px;
            margin-right: 5px;
        
            cursor: pointer; 
            border: 1px solid #fff;
             border-radius: 50%; 
             background: rgb(141, 139, 139);
        }
        #buttons .on
        {
            background:pink;
        }
        .arrow
        {font-size: 36px; 
            font-weight: bold; 
            line-height: 39px;
            position: absolute; 
            z-index: 2; 
            top: 180px; 
            display: none;
             width: 40px; 
             height: 40px;  
            cursor: pointer; 
            text-align: center; 
            color:pink;
            background-color: rgb(229, 247, 194);
        }
        .arrow:hover
        {
            background-color:rgb(194, 212, 156) ;
        }
        #container:hover .arrow
        {
            display: block;
        }
        #prev
        {
            left: 20px;
        }
        #next
        {
            right: 20px;
        }
       

最后是js逻辑:

 var  prev=document.getElementById("prev");
     var  next=document.getElementById("next");
     var  list=document.getElementById("list");
     var buttons=document.getElementById("buttons").getElementsByTagName("span");
     var index=1;
     var timer;
     var animated=false;
     var container=document.getElementById("container");

function shownButton(){
    for(var i=0;i<buttons.length;i++){
        if(buttons[i].className=="on"){
             buttons[i].className="";
             break;  
        }
    }
    buttons[index-1].className="on";
}   
function animate(offset){
    var time=100;//根据图片宽度来,最好和inteval相除为整数,不然后面移动会出问题,
    var inteval=10;
    var speed=offset/(time/inteval);
    animated=true;
    var newLeft=parseInt(list.style.left)+offset;
    function go(){
        if((speed>0&&parseInt(list.style.left)<newLeft)||(speed<0&&parseInt(list.style.left)>newLeft)){
                list.style.left=parseInt(list.style.left)+speed+"px";
                setTimeout(go,inteval);//递归函数
        }
   else{
       animated=false;
      if(newLeft>-500){//当大于第一个图的位移量切换到第4张图
             list.style.left=-2000+"px";
         };
         if(newLeft<-2000){//当小于最后一个图的位移量切换到第一张图
             list.style.left=-500+"px";
         }   
   }
    }
     go();   
     }
  prev.onclick=function(){
      if(!animated){
          if(index==1){
              index=4;//根据自己代码的index值进行修改
          }
          else{
              index-=1;
          }
          shownButton();
          animate(500);//传入图片宽度
      }
  }
  next.onclick=function(){
      if(!animated){
          if(index==4){//根据自己代码的index值进行修改
              index=1;
          }
          else{
              index+=1;
          }
          shownButton();
          animate(-500);//第一章图片宽度
      }
  }
  for(var i=0;i<buttons.length;i++){
      buttons[i].onclick=function(){
          if(this.className=="on"){
              return;
          }
          var myIndex=parseInt(this.getAttribute(index));
          var offset=-500*(myIndex-index);//偏移量根据实际情况修改
          if(!animated){
              animate(offset);
          }
          index=myIndex;
          shownButton();
      }
  }
  function play(){
      timer=setInterval(function(){
          next.onclick();
      },2000);  }
      function stop(){
          clearInterval(timer);
      }
      play();
      container.onmouseover=stop;
      container.onmouseout=play;
 

完整的代码可以去我的github下载,欢迎各位点星星和fork

https://github.com/narrow-gate/lunbo

posted on 2019-01-19 20:45  袁233  阅读(699)  评论(0编辑  收藏  举报

导航