溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何使用原生JS實(shí)現(xiàn)圖片無縫滾動(dòng)

發(fā)布時(shí)間:2021-04-21 13:48:20 來源:億速云 閱讀:215 作者:小新 欄目:web開發(fā)

小編給大家分享一下如何使用原生JS實(shí)現(xiàn)圖片無縫滾動(dòng),相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

js有什么特點(diǎn)

1、js屬于一種解釋性腳本語言;2、在絕大多數(shù)瀏覽器的支持下,js可以在多種平臺(tái)下運(yùn)行,擁有著跨平臺(tái)特性;3、js屬于一種弱類型腳本語言,對(duì)使用的數(shù)據(jù)類型未做出嚴(yán)格的要求,能夠進(jìn)行類型轉(zhuǎn)換,簡單又容易上手;4、js語言安全性高,只能通過瀏覽器實(shí)現(xiàn)信息瀏覽或動(dòng)態(tài)交互,從而有效地防止數(shù)據(jù)的丟失;5、基于對(duì)象的腳本語言,js不僅可以創(chuàng)建對(duì)象,也能使用現(xiàn)有的對(duì)象。

首先我們要實(shí)現(xiàn)的效果有以下幾點(diǎn):

小圓點(diǎn):點(diǎn)擊小圓點(diǎn)顯示與之對(duì)應(yīng)的圖片

向左和向右按鈕:點(diǎn)擊向左按鈕圖片向后運(yùn)動(dòng),點(diǎn)擊向右按鈕圖片向前運(yùn)動(dòng)

定時(shí)器:每隔 2s 自動(dòng)播放

主要難點(diǎn)在于:

當(dāng)圖片運(yùn)動(dòng)到最后一張,點(diǎn)擊向右的按鈕時(shí),應(yīng)該顯示第一張;

當(dāng)前顯示的是第一張,點(diǎn)擊向左的按鈕時(shí),應(yīng)該顯示最后一張;

思路:

1、先將第一張圖片復(fù)制 添加到 ul 最后面,將最后一張圖片復(fù)制 添加到 ul 最前面(此時(shí) ul 的第一張圖片是pic3,最后一張圖片是pic0);

2、當(dāng)圖片(ul)運(yùn)動(dòng)到pic3,繼續(xù)向前運(yùn)動(dòng),運(yùn)動(dòng)到最后一張pic0時(shí),瞬間把 ul 拉回到第二張圖片pic0的位置,然后在繼續(xù)向前運(yùn)動(dòng);

3、當(dāng)圖片(ul)向后運(yùn)動(dòng)到第一張圖片pic3時(shí),瞬間把 ul 拉回到倒數(shù)第二張圖片pic3的位置。

4、還有非常關(guān)鍵的一點(diǎn):定義iNow變量,用于對(duì)應(yīng)當(dāng)前顯示的圖片與ol中的小圓點(diǎn),并且可以用來關(guān)聯(lián) ul 的位置。

html代碼:

<div id="tab">
  <ul>
    <li><img src="image/pic0.jpg" alt="" /></li>
    <li><img src="image/pic1.jpg" alt="" /></li>
    <li><img src="image/pic2.jpg" alt="" /></li>
    <li><img src="image/pic3.jpg" alt="" /></li>
  </ul>
  <ol>
    <li class="on"></li>
    <li></li>
    <li></li>
    <li></li>
  </ol>
  <a href="javascript:;" rel="external nofollow" rel="external nofollow" class="prev" id="prev"><</a>
  <a href="javascript:;" rel="external nofollow" rel="external nofollow" class="next" id="next">></a>                 
</div>

css代碼:

*{margin: 0; padding: 0;}
li{ list-style: none;}
#tab{
  width: 670px;
  height: 240px;
  border: 1px solid #ccc;
  margin: 50px auto;
  position: relative;
}
#tab ul{
  width: 2680px;
  height: 240px;
  position: absolute;
  left: 0;
  top: 0;
  overflow: hidden;
}
#tab ul li{
  float: left;
  width: 670px;
}
#tab ul li img{
  width: 670px;
}
#tab ol{
  width: 80px;
  position: absolute;
  bottom: 10px;
  left: 50%;
  margin-left: -40px;
  overflow: hidden;
}
#tab ol li{
  float: left;
  width: 10px;
  height: 10px;
  background: #ccc;
  border-radius: 50%;
  margin: 5px;
  cursor: pointer;
}
#tab ol .on{
  background: #f00;
}
#tab .prev,#tab .next{
  display: none;
  width: 40px;
  height: 60px;
  background: rgba(0,0,0,.3);
  filter:alpha(opacity:30);
  text-decoration: none;
  text-align: center;
  line-height: 60px;
  font-size: 30px;
  color: #fff;
  position: absolute;
  top: 50%;
  margin-top: -30px;
}
#tab .prev{
  left: 0;
}
#tab .next{
  right: 0;
}

js 代碼:

其中animate()是封裝好的運(yùn)動(dòng)框架,最后面附有說明

window.onload = function(){
  var oTab = document.getElementById('tab');
  var oUl = oTab.getElementsByTagName('ul')[0];
  var aLi1 = oUl.children;
  var oOl = oTab.getElementsByTagName('ol')[0];
  var aLi2 = oOl.children;
  var prev = document.getElementById('prev');
  var next = document.getElementById('next');
  //設(shè)置ul的初始位置
  var iNow = 1;  
  oUl.style.left=-aLi1[0].offsetWidth*iNow+'px';
  //定時(shí)器
  var timer = null;

  //克隆第一張圖片 添加在ul的最后面
  var oLi1 = aLi1[0].cloneNode(true);
  //克隆最后一張圖片 添加在ul的最前面
  var oLi2 = aLi1[aLi1.length-1].cloneNode(true);
  oUl.appendChild(oLi1);
  oUl.insertBefore(oLi2,aLi1[0]);
  oUl.style.width = aLi1[0].offsetWidth*aLi1.length+"px";
  //鼠標(biāo)移入tab: 關(guān)閉定時(shí)器,左右按鈕顯示
  oTab.onmouseover = function(){
    clearInterval(timer);
    prev.style.display = 'block';
    next.style.display = 'block';
  }
  //鼠標(biāo)移出tab: 開啟定時(shí)器,左右按鈕隱藏
  oTab.onmouseout = function(){
    timer = setInterval(function(){
      toNext();
    },2000);
    prev.style.display = 'none';
    next.style.display = 'none';
  }
  //點(diǎn)擊小圓點(diǎn)
  for(var i=0;i<aLi2.length;i++){
    (function(index){
      aLi2[index].onclick = function(){
        iNow = index+1;
        for(var i=0;i<aLi2.length;i++){
          aLi2[i].className = '';
        }
        aLi2[index].className = 'on';
        animate(oUl,{left: -iNow*aLi1[0].offsetWidth});
      }
    })(i);
  }
  //上一個(gè)
  prev.onclick=function(){
    iNow--;
    animate(oUl,{left: -iNow*aLi1[0].offsetWidth},{complete:function(){
      if(iNow == 0){
        iNow = aLi1.length-2;
        oUl.style.left=-aLi1[0].offsetWidth*iNow+'px';
      }
      for(var i=0;i<aLi2.length;i++){
        aLi2[i].className = '';
      }
      aLi2[iNow-1].className = 'on';
    }});
  }
  //下一個(gè)
  next.onclick=function(){
    toNext();
  }
  function toNext(){
    iNow++;
    animate(oUl,{left: -iNow*aLi1[0].offsetWidth},{complete:function(){
      if(iNow == aLi1.length-1){
        iNow = 1;
        oUl.style.left=-aLi1[0].offsetWidth*iNow+'px';
      }
      for(var i=0;i<aLi2.length;i++){
        aLi2[i].className = '';
      }
      aLi2[iNow-1].className = 'on';
    }});
  }
  //設(shè)置定時(shí)器
  timer = setInterval(function(){
    toNext();
  },2000);
}

封裝的animate()運(yùn)動(dòng)框架

/*
 * 參數(shù)說明:
 * obj: 運(yùn)動(dòng)對(duì)象
 * json(json形式): 需要修改的屬性
 * options(json形式): 
 *       duration: 運(yùn)動(dòng)時(shí)間
 *       easing: 運(yùn)動(dòng)方式(勻速、加速、減速)
 *       complete: 運(yùn)動(dòng)完成后執(zhí)行的函數(shù)
*/
function animate(obj,json,options){
  var options=options || {};        
  var duration=options.duration || 500;  //運(yùn)動(dòng)時(shí)間,默認(rèn)值為500ms;
  var easing=options.easing || 'linear';  //運(yùn)動(dòng)方式,默認(rèn)為linear勻速
  var start={};
  var dis={};

  for(var name in json){
    start[name]=parseFloat(getStyle(obj,name));  //起始位置
    dis[name]=json[name]-start[name];      //總距離
  }

  var count=Math.floor(duration/30);         //總次數(shù)
  var n=0;  //次數(shù)

  clearInterval(obj.timer);
  obj.timer=setInterval(function(){
     if(n>count){
      clearInterval(obj.timer);
      options.complete && options.complete();
    }else{
      for(var name in json){
        switch(easing){
          //勻速
          case 'linear':
            var a=n/count;
            var cur=start[name]+dis[name]*a;  //當(dāng)前位置
            break;
          //加速
          case 'ease-in':
            var a=n/count;
            var cur=start[name]+dis[name]*a*a*a;
            break;
          //減速
          case 'ease-out':
            var a=1-n/count;
            var cur=start[name]+dis[name]*(1-a*a*a);
            break;
        }
         if(name=='opacity'){
          obj.style.opacity=cur;
          obj.style.filter = 'alpha(opacity='+cur*100+')';  //兼容IE8及以下
        }else{
          obj.style[name]=cur+'px';
        }
      }
    }
    n++;
  },30);
}
//獲取非行間樣式
function getStyle(obj,sName){
  return (obj.currentStyle || getComputedStyle(obj,false))[sName];
}

以上是“如何使用原生JS實(shí)現(xiàn)圖片無縫滾動(dòng)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

js
AI