首頁 > web前端 > js教程 > 主體

js中滑動式輪播圖是怎麼實現的?

零下一度
發布: 2017-07-09 09:40:45
原創
1461 人瀏覽過

這篇文章主要為大家詳細介紹了js實現從左向右滑動式輪播圖效果,具有一定的參考價值,有興趣的小夥伴們可以參考一下

輪播圖就是讓圖片每隔幾秒鐘自動滑動,達到圖片輪流播放的效果。輪播圖從效果來說有滑動式的也有漸入式的,滑動式的輪播圖就是圖片從左向右滑入的效果,漸入式的輪播圖就是圖片根據透明度漸漸顯示的效果,這裡說的是實現第一種效果的方法。

原理

相同大小的圖片並成一列,但只顯示其中一張圖片,其餘的隱藏,透過修改left值來改變顯示的圖片。

點選查看效果

html部分

  nav為總容器,第一個ul列表#index為小圓點列表,滑鼠覆蓋哪個小圓點就顯現第幾張圖片,on是一個為小圓點添加背景顏色屬性的類別;第二個ul列表#img為圖片列表。


  <!DOCTYPE html>
  <html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>Carousel Figure</title>
    <link rel="stylesheet" href="style.css" rel="external nofollow" >
  </head>
  <body>
  <!--从左向右滑动-->
    <nav>
      <ul id="index">
        <li class="on"></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
      </ul>
      <ul id="img">
        <li><img src="../images/img1.jpg" alt="img1"></li>
        <li><img src="../images/img2.jpg" alt="img2"></li>
        <li><img src="../images/img3.jpg" alt="img3"></li>
        <li><img src="../images/img4.jpg" alt="img4"></li>
        <li><img src="../images/img5.jpg" alt="img5"></li>
      </ul>
    </nav>
  <script src="script.js"></script>
  </body>
  </html>
登入後複製

css部分

#圖片尺寸皆為720*405,這裡要注意以下幾點:

ul#img列表相對於nav是絕對定位的,#img的長度必須設定為所有圖片的總寬度,這樣圖片才可以並列一排顯示;

總容器nav的寬度必須設定為圖片的寬度720px,即只能顯示一張圖片,超出寬度的部分隱藏,即overflow: hidden;

小圓點列表應該在圖片列表上面顯示,故設定#img的z-index:-1;

小圓點列表是由一系列的li透過改變邊框樣式構成,故只需改變背景顏色即可達到移動小圓點的效果。


  *{
    margin:0;
    padding:0;
  }
  nav{
    width: 720px;
    height: 405px;
    margin:20px auto;
    overflow: hidden;
    position: relative;
  }
  #index{
    position: absolute;
    left:320px;
    bottom: 20px;
  
  }
  #index li{
    width:8px;
    height: 8px;
    border: solid 1px gray;
    border-radius: 100%;
    background-color: #eee;
    display: inline-block;
  }
  #img{
    width: 3600px;/*不给宽高无法移动*/
    height: 405px;
    position: absolute;/*不定义absolute,js无法设置left和top*/
    z-index: -1;
  }
  #img li{
    width: 720px;
    height: 405px;
    float: left;
  }
  #index .on{
    background-color: black;
  }
登入後複製

JS部分

#圖片移動函數moveElement()

  moveElement函數需要取得圖片現在的位置以及目標位置併計算它們之間的差距進行移動,可以用offsetLeft和offsetTop取得圖片現在的位置。圖片移動時「劃過」的效果是將距離分成好10次進行移動,即利用setTimeOut函數,然而為了防止滑鼠懸停,需呼叫clearTimeout()函數,代碼如下:


  function moveElement(ele,x_final,y_final,interval){//ele为元素对象
    var x_pos=ele.offsetLeft;
    var y_pos=ele.offsetTop;
    var dist=0;
    if(ele.movement){//防止悬停
      clearTimeout(ele.movement);
    }
    if(x_pos==x_final&&y_pos==y_final){//先判断是否需要移动
      return;
    }
    dist=Math.ceil(Math.abs(x_final-x_pos)/10);//分10次移动完成
    x_pos = x_pos<x_final ? x_pos+dist : x_pos-dist;
    
    dist=Math.ceil(Math.abs(y_final-y_pos)/10);//分10次移动完成
    y_pos = y_pos<y_final ? y_pos+dist : y_pos-dist;
    
    ele.style.left=x_pos+&#39;px&#39;;
    ele.style.top=y_pos+&#39;px&#39;;
    
    ele.movement=setTimeout(function(){//分10次移动,自调用10次
      moveElement(ele,x_final,y_final,interval);
    },interval)
  }
登入後複製

小圓點移動函數moveIndex()

#  移動小圓點的實質是移動設定的背景顏色的類on,原理是先判斷哪個li上有背景顏色,有則去掉,讓所有的li都沒有背景,然後在對當前的li添加背景。


  function moveIndex(list,num){//移动小圆点
    for(var i=0;i<list.length;i++){
      if(list[i].className==&#39;on&#39;){//清除li的背景样式
        list[i].className=&#39;&#39;;
      }
    }
    list[num].className=&#39;on&#39;;
  }
登入後複製

圖片自動輪播

  將以下程式碼直接寫在window.onload中即可。
  這裡需要定義一個變數index,表示移動到第index(0~n-1,n為li的個數)張圖片。


  var img=document.getElementById(&#39;img&#39;);
  var list=document.getElementById(&#39;index&#39;).getElementsByTagName(&#39;li&#39;);
  var index=0;//这里定义index是变量,不是属性

  var nextMove=function(){//一直向右移动,最后一个之后返回
    index+=1;
    if(index>=list.length){
      index=0;
    }
    moveIndex(list,index);
    moveElement(img,-720*index,0,20);
  };
登入後複製

圖片的自動輪播需要用到setInterval()函數,讓程式每隔幾秒鐘自動呼叫nextMove()函數:


  var play=function(){
    timer=setInterval(function(){
      nextMove();
    },2500);
  };
登入後複製

滑鼠覆寫小圓點效果

#  要實作滑鼠覆寫哪個小圓點,就呈現對應的圖片這效果,需要知道滑鼠覆蓋的是哪個小圓點,這裡為每個li都加上一個自定的屬性index,使該屬性的值為對應的小圓點的序號i(0~n-1, n為li的個數),這樣每次滑鼠覆蓋時只需取得index屬性的值即可知道滑鼠覆蓋的是哪個小圓點。注意,該index屬性和變數index沒有絲毫的關係,只有相同的名字。


  for(var i=0;i<list.length;i++){//鼠标覆盖上哪个小圆圈,图片就移动到哪个小圆圈,并停止
    list[i].index=i;//这里是设置index属性,和index变量没有任何联系
    list[i].onmouseover= function () {
      var clickIndex=parseInt(this.index);
      moveElement(img,-720*clickIndex,0,20);
      index=clickIndex;
      moveIndex(list,index);
      clearInterval(timer);
    };
    list[i].onmouseout= function () {//移开后继续轮播
      play();
    };
  }
登入後複製

總結

#  輪播圖的實作並不複雜,主要在於將圖片的移動行為和小圓點的移動行為分開,這樣就比較容易實現。這個輪播圖其實還是有點問題的,從最後一幅圖滑向第一個時滑動的距離較長,其實也很好解決,將滑動的方式改一下,這裡是根據-720*index來計算最終的left值,而index是將圖片的移動和小圓點的移動綁在一起,將滑動方式改成現在的offsetLeft+(-720),圖片的移動就可以與index值無關,然後在html檔案增加一圖片:


<li><img src="../images/img1.jpg" alt="img1"></li>
<li><img src="../images/img2.jpg" alt="img2"></li>
<li><img src="../images/img3.jpg" alt="img3"></li>
<li><img src="../images/img4.jpg" alt="img4"></li>
<li><img src="../images/img5.jpg" alt="img5"></li>
<li><img src="../images/img1.jpg" alt="img1"></li>
登入後複製

然後在滑到最後一幅圖片時,迅速的將偏移量賦值0,變成第一幅,兩幅圖一樣,無法分辨其中變化,即可達到無縫連接。


  if(x_pos==-3600){
    ele.style.left=&#39;0&#39;;
    ele.style.top=&#39;0&#39;;
  }else{
    ele.style.left=x_pos+&#39;px&#39;;
    ele.style.top=y_pos+&#39;px&#39;;
  }
登入後複製

以上是js中滑動式輪播圖是怎麼實現的?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!