91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

原生JS實現的自動輪播圖功能詳解

發布時間:2020-09-11 07:43:50 來源:腳本之家 閱讀:276 作者:belong_me 欄目:web開發

本文實例講述了原生JS實現的自動輪播圖功能。分享給大家供大家參考,具體如下:

輪播圖的用處

輪播圖是現在網站網頁上最常見的效果之一,很多網站上都會用到,淘寶京東等等。有些自動選項卡也是需要用到的,而且它的可重復性高。在這里分享一下,用js原生代碼,實現輪播圖的常見效果!

輪播圖的原理

一系列的大小相等的圖片平鋪,利用CSS布局只顯示一張圖片,其余隱藏。通過定時器實現自動播放。

 原生JS實現的自動輪播圖功能詳解

Html布局

首先父容器banner存放所有內容,子容器img-list存放圖片。子容器list存放按鈕小圓點。圓點我使用了背景圖片的方式!

<div id="banner">
  <ul id="img-list">
    <li><img src="images/banner1.png" alt="1"/></li>
    <li><img src="images/banner2.jpg" alt="2"/></li>
    <li><img src="images/banner3.png" alt="3"/></li>
  </ul>
  <div id="list">
    <span index="1" class="on"></span>
    <span index="2"></span>
    <span index="3"></span>
  </div>
</div>

css修飾

1、對盒子模型,文檔流的理解,絕對定位問題。

2、圖片有固定的的寬高,先在img-list中設置三張圖片總共的寬,多余的將overflow: hidden;進行隱藏!載將其圖片下的li設置往右浮動。

3、將list span中的寬高固定,給個背景圖片。第一張圖片上設個默認的黃色圓點圖片。

#banner {
  width:100%;
  padding:0;
  clear: both;
  position: relative;
  height: 400px;
  z-index:1;
}
#img-list {
  display: block;
  width:5760px;
  height: 400px;
  overflow: hidden;
  z-index:1;
  position: relative;
}
#img-list li{
  float: left;
  width:100%;
  height: 400px;
  overflow: hidden;
  /* position: absolute;
  top:0;
  left:0; */
  z-index: 2;
}
#list {
  width:100%;
  height:18px;
  text-align: center;
  position: absolute;
  bottom: 10px;
  z-index: 100;
}
#list > span {
  width:18px;
  height: 18px;
  overflow: hidden;
  display: inline-block;
  margin:0 2px;
  background: url(../images/yuan.png);
  cursor: pointer;
}
#list .on {
  background: url(../images/huanyu.png);
}

JS效果

1、首先我們先設置自動播放的函數

2、然后鼠標滑過容器時停止播放,鼠標離開整個容器時繼續播放至下一張。

3、再定義并調用自動播放函數

var banner=document.getElementById('banner');
var imglist=document.getElementById('img-list').getElementsByTagName("li");
var list=document.getElementById('list').getElementsByTagName('span');
var index=0;
var timer=null;
//設置自動播放函數
function autoPlay () {
   if (++index >= imglist.length) {index = 0};
   changeImg(index);
}
// 鼠標劃過整個容器時停止自動播放
banner.onmouseover = function () {
   clearInterval(timer);
}
// 鼠標離開整個容器時繼續播放至下一張
banner.onmouseout=function(){
   timer=setInterval(autoPlay,2000);
}
// 定義并調用自動播放函數
timer = setInterval(autoPlay, 2000);
接著定義圖片的切換函數
// 定義圖片切換函數
function changeImg (curIndex) {
   for (var i = 0; i < imglist.length; i++) {
     imglist[i].style.display = "none";
     list[i].className = "";
   }
   imglist[curIndex].style.display = "block";
   list[curIndex].className = "on";
}

最后遍歷所有數字導航實現劃過切換至對應的圖片,需獲得它的索引值

for (var i = 0; i < list.length; i++) {
 list[i].index=i;
 list[i].onmouseover = function () {
 clearInterval(timer);
 changeImg(this.index);
};

到此為止,我們的輪播所有代碼完成!

還不算完美,繼續努力!

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript圖片操作技巧大全》、《JavaScript切換特效與技巧總結》、《JavaScript運動效果與技巧匯總》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

乌兰浩特市| 凌海市| 高台县| 石台县| 兴业县| 盐边县| 石狮市| 武宁县| 容城县| 甘肃省| 惠州市| 罗源县| 色达县| 辽宁省| 寻乌县| 永川市| 仁布县| 武清区| 齐齐哈尔市| 太仓市| 无棣县| 开封县| 平邑县| 宜兴市| 克山县| 东光县| 香港| 玛纳斯县| 清徐县| 兴文县| 青神县| 龙里县| 灵川县| 泰宁县| 沙湾县| 秭归县| 榆树市| 博白县| 九龙城区| 安丘市| 板桥市|