原生JS實現(xiàn)的自動輪播圖功能詳解
本文實例講述了原生JS實現(xiàn)的自動輪播圖功能。分享給大家供大家參考,具體如下:
輪播圖的用處
輪播圖是現(xiàn)在網(wǎng)站網(wǎng)頁上最常見的效果之一,很多網(wǎng)站上都會用到,淘寶京東等等。有些自動選項卡也是需要用到的,而且它的可重復性高。在這里分享一下,用js原生代碼,實現(xiàn)輪播圖的常見效果!
輪播圖的原理
一系列的大小相等的圖片平鋪,利用CSS布局只顯示一張圖片,其余隱藏。通過定時器實現(xiàn)自動播放。

Html布局
首先父容器banner存放所有內(nèi)容,子容器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、首先我們先設置自動播放的函數(shù)
2、然后鼠標滑過容器時停止播放,鼠標離開整個容器時繼續(xù)播放至下一張。
3、再定義并調(diào)用自動播放函數(shù)
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;
//設置自動播放函數(shù)
function autoPlay () {
if (++index >= imglist.length) {index = 0};
changeImg(index);
}
// 鼠標劃過整個容器時停止自動播放
banner.onmouseover = function () {
clearInterval(timer);
}
// 鼠標離開整個容器時繼續(xù)播放至下一張
banner.onmouseout=function(){
timer=setInterval(autoPlay,2000);
}
// 定義并調(diào)用自動播放函數(shù)
timer = setInterval(autoPlay, 2000);
接著定義圖片的切換函數(shù)
// 定義圖片切換函數(shù)
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";
}
最后遍歷所有數(shù)字導航實現(xiàn)劃過切換至對應的圖片,需獲得它的索引值
for (var i = 0; i < list.length; i++) {
list[i].index=i;
list[i].onmouseover = function () {
clearInterval(timer);
changeImg(this.index);
};
到此為止,我們的輪播所有代碼完成!
還不算完美,繼續(xù)努力!
更多關于JavaScript相關內(nèi)容感興趣的讀者可查看本站專題:《JavaScript圖片操作技巧大全》、《JavaScript切換特效與技巧總結》、《JavaScript運動效果與技巧匯總》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調(diào)試技巧總結》、《JavaScript數(shù)據(jù)結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數(shù)學運算用法總結》
希望本文所述對大家JavaScript程序設計有所幫助。
相關文章
JavaScript實現(xiàn)的開關燈泡點擊切換特效示例
這篇文章主要介紹了JavaScript實現(xiàn)的開關燈泡點擊切換特效,涉及javascript事件響應及頁面元素屬性動態(tài)操作相關實現(xiàn)技巧,需要的朋友可以參考下2019-07-07
javascript中的altKey 和 Event屬性大全
本文給大家介紹javascript中的altkey和event屬性大全,涉及到altkey和event屬性語法定義及用法,本文介紹的非常詳細,感興趣的朋友一起看看吧2015-11-11

