欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

原生JS實(shí)現(xiàn)圖片輪播切換效果

 更新時間:2016年12月15日 09:03:19   作者:辣姐什么鬼  
這篇文章主要為大家詳細(xì)介紹了原生JS實(shí)現(xiàn)圖片輪播切換效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下

首先來分析一下輪播圖效果的實(shí)現(xiàn)原理:

1、父元素作為顯示窗口,大小固定超出部分隱藏,即設(shè)置overflow:hidden;

2、子元素存放圖片列表用ul,ul固定定位,參照為父元素,即父元素position:relative;ul元素position:absolute;

3、一個li即一張圖片的寬度為父元素的顯示寬度

4、初始時,ul的left為0,這時第一張圖片即第一個li顯示

5、點(diǎn)擊下一張按鈕,將整個ul左移,使第二個li對齊父元素的左邊框,此時ul的left為負(fù)的一個li的寬度

6、點(diǎn)擊上一張按鈕,將整個ul右移

7、對特殊情況進(jìn)行處理,即第一張圖時點(diǎn)上一張,最后一張圖時點(diǎn)下一張

第一張圖時點(diǎn)上一張,我們滾動到最后一張圖,整個ul左移,即把left值改為負(fù)的n-1張圖的寬度;

最后一張圖時點(diǎn)下一張,我們滾到第一張圖的位置,整個ul右移,即把left值改為0

用一張圖來幫助理解:

修改ul元素的left值很簡單ul.style.left=設(shè)定值,就可以了,但我們想有一個滑動的效果,那我們需要用setInterval來實(shí)現(xiàn)

最后的效果如下:


動圖不能錄制太大CSDN有2M的限制_(:зゝ∠)_

下面放代碼

script部分

<script>
 window.onload= function () {
  var nav=document.getElementById("nav").getElementsByTagName("li");
  var img=document.getElementById("imgList");
  var prev=document.getElementById("prev");
  var next=document.getElementById("next");
  var index=0;//當(dāng)前圖片序列號
  var timer;//定時器名字
  var iSpeed=-10;//滾動的速度
  function goRoll(){
   timer=setInterval(function () {
    img.style.left=img.offsetLeft+iSpeed+'px';
    var stop=-index*870+'px';//當(dāng)達(dá)到目標(biāo)位置是停止定時器
    if(img.style.left==stop){
     iSpeed=-10;
     clearInterval(timer);
    }
   },10)
  }
//  上一張和下一張點(diǎn)擊效果
  prev.onclick= function () {
   if(index==0){
    index=2;
    iSpeed=-20;
   }else{
    index--;
    iSpeed=10;
   }
   goRoll();
   //img.style.left=-index*870+'px';

  };
  next.onclick= function () {
   if(index==2){
    index=0;
    iSpeed=20;
   }else{
    index++;
    iSpeed=-10;
   }
   goRoll();
   //img.style.left=-index*870+'px';
  };
 }
</script>

html放一下

<div class="panel center-panel bc_rice">
 <div class="panel-box">
  <a class="prev-btn" id="prev"></a>
  <div class="img-box">
   <div class="list-box">
    <ul class="img-list" id="imgList">
     <li>
      <img src="img/c1.jpg"/>
     </li>
     <li>
      <img src="img/c2.jpg"/>
     </li>
     <li>
      <img src="img/c3.jpg"/>
     </li>
    </ul>
   </div>
  </div>
  <a class="next-btn" id="next"></a>
  <img class="mT20" src="img/shadow1.png"/>
 </div>
 <div class="center-line bc_brown"></div>
</div>

CSS放一下

.fb{font-weight:bold;}
.c_fff{color:#fff;}
.f24{font-size:24px;}
.f72{font-size:72px;}
.lh40{line-height:40px;}
.bc_brown{background:#533d3b;}
.bc_green{background:#74cdab;}
.bc_rice{background:#ecf1c8;}
.bc_beige{background:#d1d5b0;}
.mT10{margin-top:10px;}
.mT20{margin-top:20px;}
.mT30{margin-top:30px;}
.mT40{margin-top:40px;}
.tc{text-align:center;}
.dblock{display:block;}
.clearfix:after{content:'';display:block;visibility:hidden;clear:both;line-height:0;font-size:0;}
.clearfix{zoom:1;}
html,body{width:100%;height:100%;font-size:14px;font-family:Myriad Pro;color:#433c3c;}
div,p,a,span,ul,li,em{margin:0;padding:0;}
ul li{list-style-type:none;}
a:hover{cursor:pointer;}
/*main-panel*/
.main-panel{width:100%;min-width:1030px;margin:0 auto;}
.main-panel .panel{width:100%;}
.main-panel .panel .line{width:100%;height:23px;background:url('../img/line.png');}
.main-panel .panel .panel-box{width:960px;height:100%;margin:0 auto;overflow:hidden;position:relative;}
.center-panel{height:510px;position:relative;}
.center-panel .panel-box{width:990px;z-index:1000;}
.center-panel .center-line{height:76px;position:absolute;width:100%;top:200px;z-index:10;}
.center-panel .panel-box a{width:51px;height:82px;display:block;position:absolute;top:200px;}
.center-panel .prev-btn{background:url('../img/Button-left.png');left:0;}
.center-panel .next-btn{background:url('../img/Button-right.png');right:0;}
.center-panel .img-box{width:940px;height:366px;background:url('../img/shadow.png');margin-top:45px;margin-left:10px;overflow:hidden;}
.center-panel .list-box{width:870px;height:334px;margin:16px auto;overflow:hidden;position:relative;}
.center-panel .img-list{width:4000px;height:334px;position:absolute;left:0;}
.center-panel .img-list li{width:870px;height:100%;float:left;}


因?yàn)槲覍懥艘徽麄€頁面都放出來沒啥用,所以我只截取了用到的部分。
現(xiàn)在還是有些問題的,比如如果點(diǎn)擊過快是會出問題的,這個以后看看能不能完善。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 刪除條目時彈出的確認(rèn)對話框

    刪除條目時彈出的確認(rèn)對話框

    這篇文章主要介紹用js的confirm實(shí)現(xiàn)的刪除條目時彈出的確認(rèn)對話框,詢問是否要刪除這條記錄,需要的朋友可以參考下
    2014-06-06
  • js 將線性數(shù)據(jù)轉(zhuǎn)為樹形的示例代碼

    js 將線性數(shù)據(jù)轉(zhuǎn)為樹形的示例代碼

    這篇文章主要介紹了js 將線性數(shù)據(jù)轉(zhuǎn)為樹形的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • 純JS實(shí)現(xiàn)五子棋游戲

    純JS實(shí)現(xiàn)五子棋游戲

    這篇文章主要為大家詳細(xì)介紹了純JS實(shí)現(xiàn)五子棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • JS 中document.URL 和 windows.location.href 的區(qū)別

    JS 中document.URL 和 windows.location.href 的區(qū)別

    實(shí)際上,document 和 windows 這兩個對象的區(qū)別已經(jīng)包含了這個問題的答案。
    2009-11-11
  • JavaScript必知必會(二) null 和undefined

    JavaScript必知必會(二) null 和undefined

    這篇文章主要介紹了JavaScript必知必會(二) null 和undefined的相關(guān)資料,非常不錯具有參考借鑒價值,需要的朋友可以參考下
    2016-06-06
  • 深入了解JavaScript中遞歸的理解與實(shí)現(xiàn)

    深入了解JavaScript中遞歸的理解與實(shí)現(xiàn)

    本文將通過遞歸的經(jīng)典案例:求斐波那契數(shù)來講解遞歸,通過畫遞歸樹的方式來講解其時間復(fù)雜度和空間復(fù)雜度以及遞歸的執(zhí)行順序,感興趣的可以了解一下
    2022-06-06
  • JS如何在數(shù)組指定位置插入元素

    JS如何在數(shù)組指定位置插入元素

    這篇文章主要介紹了JS如何在數(shù)組指定位置插入元素,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-03-03
  • JavaScript操作選擇對象的簡單實(shí)例

    JavaScript操作選擇對象的簡單實(shí)例

    下面小編就為大家?guī)硪黄狫avaScript操作選擇對象的簡單實(shí)例。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考,一起跟隨小編過來看看吧
    2016-05-05
  • js實(shí)現(xiàn)固定寬高滑動輪播圖效果

    js實(shí)現(xiàn)固定寬高滑動輪播圖效果

    本文主要分享了js實(shí)現(xiàn)PC固定寬高滑動輪播圖效果的示例代碼。具有一定的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • Javascript操作select控件代碼實(shí)例

    Javascript操作select控件代碼實(shí)例

    這篇文章主要介紹了Javascript操作select控件代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-02-02

最新評論