JavaScript實現輪播圖效果代碼實例

 更新時間:2019-09-29 04:00:24   作者:佚名   我要評論(0)

這篇文章主要介紹了JavaScript實現輪播圖效果代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

這篇文章主要介紹了JavaScript實現輪播圖效果代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

HTML部分:

<!-- HTML部分 -->
<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title>輪播圖</title>
    <link rel="stylesheet" type="text/css" href="css/demo06.css" rel="external nofollow" />
    <script src="js/demo06.js"></script>
  </head>
  <body>
    <div class="container">
      <!-- 輪播圖區域 -->
      <ul class="lbimg">
        <li class="on" style="background-color: #898989;">輪播圖1</li>
        <li style="background-color: #CD282B;">輪播圖2</li>
        <li style="background-color: pink;">輪播圖3</li>
        <li style="background-color: peachpuff;">輪播圖4</li>
        <li style="background-color: palegoldenrod;">輪播圖5</li>
      </ul>  
      <ol class="btn">
        <li class="active">第1張</li>
        <li>第2張</li>
        <li>第3張</li>
        <li>第4張</li>
        <li>第5張</li>
      </ol>
    </div>
  </body>
</html>

CSS部分

*{
  margin: 0;
  padding: 0;
  list-style: none;
}
.container{
  width: 600px;
  height: 400px;
  border: 4px double #FF6633;
  margin: 0 auto;
}

/* 輪播圖 */
.lbimg li{
  width: 100%;
  height: 350px;
  text-align: center;
  line-height: 350px;
  display: none;
  font-size: 25px;
  color: #FF6633;
}
.lbimg .on{
  display: block;
}

.btn{
  width: 100%;
  height: 50px;
  background-color: #3CBDFF;
  display: flex;
}
.btn li{
  flex: 1;
  color: #fff;
  font-weight: bold;
  line-height: 50px;
  text-align: center;
  font-family: "楷體";
  cursor: pointer;
  
}
.btn .active{
  background-color: rgba(0,0,0,0.2);
  transition: all ease-in-out 0.25s;
}

JavaScript部分

window.onload=function(){
  var lbimg=document.querySelector(".lbimg");
  var lbimgs=lbimg.querySelectorAll("li");
  var btn=document.querySelector(".btn");
  var btns=btn.querySelectorAll("li");
  
  for (var i = 0; i < btns.length; i++) {
    
    btns[i].index=i;
    btns[i].onclick=function(){
      clearInterval(timer);
      for (var j = 0; j < lbimgs.length; j++) {
        lbimgs[j].className="";
      }
      // 按鈕顏色跟著變化
      for(var k=0;k<btns.length;k++){
        btns[k].className="";
      }
      // 輪播同步,點擊后圖片的位置從點擊的地方開始輪播
      index=this.index;
      btns[this.index].className="active";
      lbimgs[this.index].className="on";
      timer=setInterval(autoPlay,1000);
    }
  }
  var index=0;
  // 自動輪播
  index++;
  var timer=setInterval(autoPlay,1000);
  function autoPlay(){
    for (var i = 0; i < lbimgs.length; i++) {
      lbimgs[i].className="";
    }
    for (var j = 0; j < btns.length; j++) {
      btns[j].className="";
    }
    if(index==lbimgs.length-1){
      index=0;
    }else{
      index++;
    }
    btns[index].className="active";
    lbimgs[index].className="on";
  }
  
  // 鼠標移動時清除定時器
  lbimg.onmouseover=function(){
    clearInterval(timer);
  }
  lbimg.onmouseout=function(){
    timer=setInterval(autoPlay,1000);
  }
  
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:

  • js實現圖片3D輪播效果
  • vue.js+elementUI實現點擊左右箭頭切換頭像功能(類似輪播圖效果)
  • javascript實現圖片輪播代碼
  • JS實現圖片輪播效果實例詳解【可自動和手動】
  • 原生js實現移動端Touch輪播圖的方法步驟
  • 原生JS實現的自動輪播圖功能詳解
  • 原生JS實現手動輪播圖效果實例代碼

相關文章

最新評論

亿宝娱乐黑钱