本文實例講述了原生JS實現(xiàn)的自動輪播圖功能。分享給大家供大家參考,具體如下:
創(chuàng)新互聯(lián)公司網(wǎng)站建設(shè)由有經(jīng)驗的網(wǎng)站設(shè)計師、開發(fā)人員和項目經(jīng)理組成的專業(yè)建站團隊,負(fù)責(zé)網(wǎng)站視覺設(shè)計、用戶體驗優(yōu)化、交互設(shè)計和前端開發(fā)等方面的工作,以確保網(wǎng)站外觀精美、成都做網(wǎng)站、網(wǎng)站設(shè)計易于使用并且具有良好的響應(yīng)性。
輪播圖的用處
輪播圖是現(xiàn)在網(wǎng)站網(wǎng)頁上最常見的效果之一,很多網(wǎng)站上都會用到,淘寶京東等等。有些自動選項卡也是需要用到的,而且它的可重復(fù)性高。在這里分享一下,用js原生代碼,實現(xiàn)輪播圖的常見效果!
輪播圖的原理
一系列的大小相等的圖片平鋪,利用CSS布局只顯示一張圖片,其余隱藏。通過定時器實現(xiàn)自動播放。
Html布局
首先父容器banner存放所有內(nèi)容,子容器img-list存放圖片。子容器list存放按鈕小圓點。圓點我使用了背景圖片的方式!
css修飾
1、對盒子模型,文檔流的理解,絕對定位問題。
2、圖片有固定的的寬高,先在img-list中設(shè)置三張圖片總共的寬,多余的將overflow: hidden;
進行隱藏!載將其圖片下的li設(shè)置往右浮動。
3、將list span中的寬高固定,給個背景圖片。第一張圖片上設(shè)個默認(rèn)的黃色圓點圖片。
#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è)置自動播放的函數(shù)
2、然后鼠標(biāo)滑過容器時停止播放,鼠標(biāo)離開整個容器時繼續(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è)置自動播放函數(shù) function autoPlay () { if (++index >= imglist.length) {index = 0}; changeImg(index); } // 鼠標(biāo)劃過整個容器時停止自動播放 banner.onmouseover = function () { clearInterval(timer); } // 鼠標(biāo)離開整個容器時繼續(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ù)字導(dǎo)航實現(xiàn)劃過切換至對應(yīng)的圖片,需獲得它的索引值
for (var i = 0; i < list.length; i++) { list[i].index=i; list[i].onmouseover = function () { clearInterval(timer); changeImg(this.index); };
到此為止,我們的輪播所有代碼完成!
還不算完美,繼續(xù)努力!
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript圖片操作技巧大全》、《JavaScript切換特效與技巧總結(jié)》、《JavaScript運動效果與技巧匯總》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。