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

原JS實(shí)現(xiàn)banner圖的常用功能

 更新時(shí)間:2017年06月12日 09:57:35   作者:Mr.聶  
這篇文章主要為大家詳細(xì)介紹了原JS實(shí)現(xiàn)banner圖的常用功能,,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

雖然,用jQuery實(shí)現(xiàn)banner圖的各種效果十分簡單快捷,但是我今天用css+js代碼實(shí)現(xiàn)了幾個(gè)banner圖的常用功能,效果還不錯(cuò)。

此次,主要想實(shí)現(xiàn)以下功能:

  1. banner圖循環(huán)不間斷切換

  2. 通過自制按鈕實(shí)現(xiàn)指定性banner圖的切換

  3. 通過方向按鈕實(shí)現(xiàn)banner圖左/右定向依次切換

  4. 當(dāng)banner圖存在onmouseover事件時(shí),停止banner切換,當(dāng)存在onmouseout時(shí)繼續(xù)切換

<!DOCTYPE html>
<html>
 <head>
  <meta charset="UTF-8">
  <title></title>
  <style type="text/css">
   #banner{
    width: 716.8px;
    height: 537.6px;
    background-color: aquamarine;
    margin: 100px auto;
    position: relative;
    font-size: 0px;  /*清除img圖片間的回車符產(chǎn)生的間隔*/
    overflow: hidden;
   }
   #banner #bannerImg{
    width: 100%;
    position: absolute;
    top: 0px;
    left: 0px;
    white-space: nowrap; /*使這個(gè)圖片能一行顯示*/
    transition:all 1s linear;
   }
   #banner #bannerImg .img{
    width: 100%;
   }
   #banner #bannerButton{
    font-size: 16px;
    color: white;
    position: absolute;
    bottom: 10px;
    left: 20px;
   }
   #banner #bannerButton .Button{
    border-radius: 9px;
    border: none;
    outline: none;
    cursor: pointer;
    background-color: #7FFFD4;
   }
   #banner #bannerButtonAside .div1{
    position: absolute;
    right: 10px;
    top: 50%;
    margin-top: -32px;
    cursor: pointer;
   }
   
   #banner #bannerButtonAside .div2{
    position: absolute;
    left: 10px;
    top: 50%;
    margin-top: -32px;
    cursor: pointer;
   }
  </style>
 </head>
 <body>
  <!--實(shí)現(xiàn) 左右按鈕,1234,自動(dòng)滑動(dòng),鼠標(biāo)停上顯示小手不動(dòng) 暫停。-->
  <section id="banner" onmouseover="changeStop()" onmouseout="changeStart()">
   
   <!--以下是我們的banner圖-->
   <div id="bannerImg">
    <img class="img" src="../img/c95d7b9676ae739cccfc55457b93fe9c.jpg"/>
    <img class="img" src="../img/5f5bdebddd8f1d276aeac8af5f8fa38d.jpg"/>
    <img class="img" src="../img/5f5e5c091ecb0525fc8204f200670dd9.jpg"/>
    <img class="img" src="../img/efa11cad9094f951061ee21324277efe.jpg"/>
    <img class="img" src="../img/0b54c021bd4384c168d835dfc0908018.jpg"/>
    <img class="img" src="../img/25d10d413faca3bdd7e2d88667f4298f_看圖王.jpg"/>
    <img class="img" src="../img/c95d7b9676ae739cccfc55457b93fe9c.jpg"/> <!--第7張與第一張為同一圖片,消除圖片切換間斷-->
   </div>
   
   <!--以下是我們左下方的banner圖按鈕-->
   <div id="bannerButton">
    <button class="Button" onclick="buttonChange(0)">1</button>
    <button class="Button" onclick="buttonChange(1)">2</button>
    <button class="Button" onclick="buttonChange(2)">3</button>
    <button class="Button" onclick="buttonChange(3)">4</button>
    <button class="Button" onclick="buttonChange(4)">5</button>
    <button class="Button" onclick="buttonChange(5)">6</button>
   </div>
   
   <!--以下是我們左右兩個(gè)方向按鈕-->
   <div id="bannerButtonAside">
    <div class="div1" onclick="asideChange(1)">
     <img src="../img/forword.png"/>
    </div>
    <div class="div2" onclick="asideChange(0)">
     <img src="../img/back.png"/>
    </div>
   </div>
  </section>
 </body>
 
 <script type="text/javascript">
  var bannerImg=document.getElementById("bannerImg"); /*取出img容器的節(jié)點(diǎn)*/
  var Button=document.getElementsByClassName("Button"); /*取出所有的button按鈕*/
  var num=0;  /*定義全局變量num,控制banner的切換次序*/
  var aaa=0;  /*定義一個(gè)全局變量,用來取定時(shí)器函數(shù),并在沒有鼠標(biāo)事件的時(shí)候清除定時(shí)器*/
   
  /*通過定時(shí)器實(shí)現(xiàn)banner圖的每3000毫秒切換一次的效果的changeStart()函數(shù)*/
  function changeStart(){
    aaa=setInterval(function(){
    if (num<=6) {
     bannerImg.style.transition="all 1s linear";
     bannerImg.style.left=(-716.8)*(num)+"px";
     num++;
    }else{
     bannerImg.style.transition="all 0s linear";  /*消除num=0時(shí),bannerImg移動(dòng)的過渡效果*/
     num=0;
     bannerImg.style.left=(-716.8)*(num)+"px";
     
    }
    console.log("哈哈哈繼續(xù)");
   },3000)
  }
  changeStart();
  
  /*以下是當(dāng)鼠標(biāo)懸浮在banner圖上時(shí),圖片停止自動(dòng)切換的changeStop()函數(shù)*/
  function changeStop(){
   clearInterval(aaa); 
   console.log("停止他");
  }
  
  /*以下是點(diǎn)擊按鈕實(shí)現(xiàn)對應(yīng)banner圖切換的change()函數(shù)*/
  function buttonChange(Num){
   num=Num+1;
   bannerImg.style.transition="all 0s linear";
   bannerImg.style.left=(-716.8)*(Num)+"px";
  }
  
  /*以下是點(diǎn)擊左右兩個(gè)按鈕實(shí)現(xiàn)banner圖切換的buttonChange()函數(shù)*/
  function asideChange(x){ /*通過傳遞形參x,判斷往左/往右切換banner圖*/
   if (num!=6&&x==1) {
    num++;
   }else if(num==6&&x==1){
    num=0;
   }else if(num!=0&&x==0){
    num--;
   }
   else if(num==0&&x==0){
    num=5;
   }
   bannerImg.style.transition="all 0s linear";
   bannerImg.style.left=(-716.8)*(num)+"px";
  }
 </script>
</html> 

  但是經(jīng)過博主的測試,發(fā)現(xiàn)程序存在一定的瑕疵,第一張圖片的保留時(shí)間比其他圖片長,而且每次重新開啟定時(shí)器均存在這個(gè)問題。暫時(shí)博主還沒有比較簡單

省事的方法改良他,所以僅供參考思路,以后要用,當(dāng)然還是jQuery省事啦!

  如果存在錯(cuò)誤,歡迎朋友們指出,我們一起探討,改良代碼!

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

相關(guān)文章

  • 微信小程序中使用ECharts 異步加載數(shù)據(jù)的方法

    微信小程序中使用ECharts 異步加載數(shù)據(jù)的方法

    這篇文章主要介紹了微信小程序中使用ECharts 異步加載數(shù)據(jù)的方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-06-06
  • JS數(shù)組按指定字段轉(zhuǎn)map-list結(jié)構(gòu)(示例詳解)

    JS數(shù)組按指定字段轉(zhuǎn)map-list結(jié)構(gòu)(示例詳解)

    在開發(fā)過程中經(jīng)常會(huì)出現(xiàn)接口返回整個(gè)數(shù)組,我們需要將數(shù)組進(jìn)行二次處理,這篇文章主要介紹了js?數(shù)組按指定字段轉(zhuǎn)map-list結(jié)構(gòu),需要的朋友可以參考下
    2023-11-11
  • IE瀏覽器PNG圖片透明效果代碼

    IE瀏覽器PNG圖片透明效果代碼

    平常,我們經(jīng)常使用Gif格式的圖片以保持圖片在瀏覽器中透明,以支持底色。但由于IE瀏覽器本身的原因,我們無法使透明的PNG圖片透明起來。那么,如何將它在IE瀏覽器下變得透明呢?
    2008-09-09
  • 微信小程序中使用echarts的實(shí)現(xiàn)方法

    微信小程序中使用echarts的實(shí)現(xiàn)方法

    這篇文章主要介紹了微信小程序中使用echarts的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • JS實(shí)現(xiàn)瀏覽上傳文件的代碼

    JS實(shí)現(xiàn)瀏覽上傳文件的代碼

    本文通過實(shí)例代碼給大家介紹了基于js實(shí)現(xiàn)瀏覽上傳文件的代碼,非常不錯(cuò),代碼簡單易懂,具有參考借鑒價(jià)值,需要的朋友參考下吧
    2017-08-08
  • JavaScript仿京東秒殺倒計(jì)時(shí)

    JavaScript仿京東秒殺倒計(jì)時(shí)

    這篇文章主要為大家詳細(xì)介紹了JavaScript仿京東秒殺倒計(jì)時(shí),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • 純JS實(shí)現(xiàn)五子棋游戲兼容各瀏覽器(附源碼)

    純JS實(shí)現(xiàn)五子棋游戲兼容各瀏覽器(附源碼)

    純JS實(shí)現(xiàn)五子棋游戲同時(shí)兼容各個(gè)主流瀏覽器,感興趣的朋友可以下載源碼學(xué)習(xí)下也是對你js技巧的晉級(jí)
    2013-04-04
  • 微信小程序頂部可滾動(dòng)導(dǎo)航效果

    微信小程序頂部可滾動(dòng)導(dǎo)航效果

    最近領(lǐng)導(dǎo)安排做一個(gè)小程序之做頭部做導(dǎo)航分類效果,下面小編給大家分享實(shí)現(xiàn)代碼,需要的朋友參考下吧
    2017-10-10
  • JavaScript實(shí)現(xiàn)涂鴉筆功能

    JavaScript實(shí)現(xiàn)涂鴉筆功能

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)涂鴉筆功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • JS判斷客服QQ號(hào)在線還是離線狀態(tài)的方法

    JS判斷客服QQ號(hào)在線還是離線狀態(tài)的方法

    這篇文章主要介紹了JS判斷客服QQ號(hào)在線還是離線狀態(tài)的方法,可實(shí)現(xiàn)完整的判斷QQ在線及對話的功能,是非常實(shí)用的技巧,需要的朋友可以參考下
    2015-01-01

最新評(píng)論