天天看點

原生态JS實作banner圖的常用所有功能

  雖然,用jQuery實作banner圖的各種效果十分簡單快捷,但是我今天用css+js代碼實作了幾個banner圖的常用功能,效果還不錯。

此次,主要想實作以下功能:

  1. banner圖循環不間斷切換

  2. 通過自制按鈕實作指定性banner圖的切換

  3. 通過方向按鈕實作banner圖左/右定向依次切換

  4. 當banner圖存在onmouseover事件時,停止banner切換,當存在onmouseout時繼續切換

1 <!DOCTYPE html>       2 <html>       3     <head>       4         <meta charset="UTF-8">       5         <title></title>       6         <style type="text/css">       7             #banner{       8                 width: 716.8px;       9                 height: 537.6px;      10                 background-color: aquamarine;      11                 margin: 100px auto;      12                 position: relative;      13                 font-size: 0px;        /*清除img圖檔間的回車符産生的間隔*/      14                 overflow: hidden;      15             }      16             #banner #bannerImg{      17                 width: 100%;      18                 position: absolute;      19                 top: 0px;      20                 left: 0px;      21                 white-space: nowrap;    /*使這個圖檔能一行顯示*/      22                 transition:all 1s linear;      23             }      24             #banner #bannerImg .img{      25                 width: 100%;      26             }      27             #banner #bannerButton{      28                 font-size: 16px;      29                 color: white;      30                 position: absolute;      31                 bottom: 10px;      32                 left: 20px;      33             }      34             #banner #bannerButton .Button{      35                 border-radius: 9px;      36                 border: none;      37                 outline: none;      38                 cursor: pointer;      39                 background-color: #7FFFD4;      40             }      41             #banner #bannerButtonAside .div1{      42                 position: absolute;      43                 right: 10px;      44                 top: 50%;      45                 margin-top: -32px;      46                 cursor: pointer;      47             }      48                   49             #banner #bannerButtonAside .div2{      50                 position: absolute;      51                 left: 10px;      52                 top: 50%;      53                 margin-top: -32px;      54                 cursor: pointer;      55             }      56         </style>      57     </head>      58     <body>      59         <!--實作 左右按鈕,1234,自動滑動,滑鼠停上顯示小手不動 暫停。-->      60         <section id="banner" onmouseover="changeStop()" onmouseout="changeStart()">      61                   62             <!--以下是我們的banner圖-->      63             <div id="bannerImg">      64                 <img class="img" src="../img/c95d7b9676ae739cccfc55457b93fe9c.jpg"/>      65                 <img class="img" src="../img/5f5bdebddd8f1d276aeac8af5f8fa38d.jpg"/>      66                 <img class="img" src="../img/5f5e5c091ecb0525fc8204f200670dd9.jpg"/>      67                 <img class="img" src="../img/efa11cad9094f951061ee21324277efe.jpg"/>      68                 <img class="img" src="../img/0b54c021bd4384c168d835dfc0908018.jpg"/>      69                 <img class="img" src="../img/25d10d413faca3bdd7e2d88667f4298f_看圖王.jpg"/>      70                 <img class="img" src="../img/c95d7b9676ae739cccfc55457b93fe9c.jpg"/>    <!--第7張與第一張為同一圖檔,消除圖檔切換間斷-->      71             </div>      72                   73             <!--以下是我們左下方的banner圖按鈕-->      74             <div id="bannerButton">      75                 <button class="Button" onclick="buttonChange(0)">1</button>      76                 <button class="Button" onclick="buttonChange(1)">2</button>      77                 <button class="Button" onclick="buttonChange(2)">3</button>      78                 <button class="Button" onclick="buttonChange(3)">4</button>      79                 <button class="Button" onclick="buttonChange(4)">5</button>      80                 <button class="Button" onclick="buttonChange(5)">6</button>      81             </div>      82                   83             <!--以下是我們左右兩個方向按鈕-->      84             <div id="bannerButtonAside">      85                 <div class="div1" onclick="asideChange(1)">      86                     <img src="../img/forword.png"/>      87                 </div>      88                 <div class="div2" onclick="asideChange(0)">      89                     <img src="../img/back.png"/>      90                 </div>      91             </div>      92         </section>      93     </body>      94           95     <script type="text/javascript">      96         var bannerImg=document.getElementById("bannerImg");    /*取出img容器的節點*/      97         var Button=document.getElementsByClassName("Button");    /*取出所有的button按鈕*/      98         var num=0;     /*定義全局變量num,控制banner的切換次序*/      99         var aaa=0;     /*定義一個全局變量,用來取定時器函數,并在沒有滑鼠事件的時候清除定時器*/     100                  101         /*通過定時器實作banner圖的每3000毫秒切換一次的效果的changeStart()函數*/     102         function changeStart(){     103                 aaa=setInterval(function(){     104                 if (num<=6) {     105                     bannerImg.style.transition="all 1s linear";     106                     bannerImg.style.left=(-716.8)*(num)+"px";     107                     num++;     108                 }else{     109                     bannerImg.style.transition="all 0s linear";        /*消除num=0時,bannerImg移動的過渡效果*/     110                     num=0;     111                     bannerImg.style.left=(-716.8)*(num)+"px";     112                          113                 }     114                 console.log("哈哈哈繼續");     115             },3000)     116         }     117         changeStart();     118              119         /*以下是當滑鼠懸浮在banner圖上時,圖檔停止自動切換的changeStop()函數*/     120         function changeStop(){     121             clearInterval(aaa);         122             console.log("停止他");     123         }     124              125         /*以下是點選按鈕實作對應banner圖切換的change()函數*/     126         function buttonChange(Num){     127             num=Num+1;     128             bannerImg.style.transition="all 0s linear";     129             bannerImg.style.left=(-716.8)*(Num)+"px";     130         }     131              132         /*以下是點選左右兩個按鈕實作banner圖切換的buttonChange()函數*/     133         function asideChange(x){   /*通過傳遞形參x,判斷往左/往右切換banner圖*/     134             if (num!=6&&x==1) {     135                 num++;     136             }else if(num==6&&x==1){     137                 num=0;     138             }else if(num!=0&&x==0){     139                 num--;     140             }     141             else if(num==0&&x==0){     142                 num=5;     143             }     144             bannerImg.style.transition="all 0s linear";     145             bannerImg.style.left=(-716.8)*(num)+"px";     146         }     147     </script>     148 </html>      

  但是經過部落客的測試,發現程式存在一定的瑕疵,第一張圖檔的保留時間比其他圖檔長,而且每次重新開啟定時器均存在這個問題。暫時部落客還沒有比較簡單

省事的方法改良他,是以僅供參考思路,以後要用,當然還是jQuery省事啦!

  如果存在錯誤,歡迎朋友們指出,我們一起探讨,改良代碼!

繼續閱讀