HTML5輪播圖全代碼

輪播圖原理大概是這樣的,假定三張圖片需要做輪播效果,首先需要將這三張圖片并列放置,然后將這個(gè)整體并列向左移動(dòng),每當(dāng)一張圖片完整的從顯示框走出,則將這張圖片放置到最后面,循環(huán)往復(fù)就可以實(shí)現(xiàn)圖片向左(或一個(gè)方向)移動(dòng)。然后,需要有兩個(gè)定時(shí)器,一個(gè)定時(shí)器A控制三張圖片整體左移速度,另一個(gè)定時(shí)器B控制每當(dāng)一張完整的圖片走進(jìn)這個(gè)顯示框就等待一到兩秒得到更好的用戶體驗(yàn)。
我這里用三個(gè)div框當(dāng)作輪播圖來演示。
在html的body中添加一個(gè)div作為顯示框,然后在這個(gè)div內(nèi)部添加三個(gè)子div作為圖片顯示。代碼如下:
<div id="box"> <div id="red" class="slide"></div> <div id="green" class="slide"></div> <div id="blue" class="slide"></div> </div>
頭部添加css樣式:
此時(shí)網(wǎng)頁中應(yīng)該是有一個(gè)黑色顯示框div,內(nèi)部有紅、綠、藍(lán)三個(gè)div框,三個(gè)框從上到下排列。
第一步,需要將三張圖片都并列顯示。
要實(shí)現(xiàn)將div挪動(dòng),且div比較方便控制每時(shí)每刻的位置(移動(dòng)),只能使用相對定位,且為方便,三個(gè)子div位置移動(dòng)應(yīng)該是相對box,所以box應(yīng)該作為相對的參照點(diǎn)。分別為box和slide代碼添加position屬性:
#box{ width:100px; height:100px; border:1px solid black; position:relative; } .slide{ width:100px; height:100px; position:absolute; }
為整個(gè)頁面添加onload加載完成事件,當(dāng)瀏覽器打開并加載完并自動(dòng)執(zhí)行事件中的代碼塊。這部分js代碼寫在剛才css下面即可,保持同級結(jié)構(gòu)。
<script type="text/javascript"> onload=function(){ var arr = document.getElementsByClassName("slide"); for(var i=0;i<arr.length;i++){ arr[i].style.left = i*100+"px"; } } </script>
當(dāng)頁面加載完全,三個(gè)div應(yīng)該并列在一起。
接下來,需要實(shí)現(xiàn)將這三個(gè)div整體向左移動(dòng),使用定時(shí)器,即前面的定時(shí)器A。*onload同級下面添加如下代碼:
function LeftMove(){ var arr = document.getElementsByClassName("slide");//獲取三個(gè)子div for(var i=0;i<arr.length;i++){ var left = parseFloat(arr[i].style.left); left-=2; var width = 100;//圖片的寬度 if(left<=-width){ left=(arr.length-1)*width;//當(dāng)圖片完全走出顯示框,拼接到末尾 } arr[i].style.left = left+"px"; } } moveId=setInterval(LeftMove,10);//設(shè)置一個(gè)10毫秒定時(shí)器,并給自己取名 **此時(shí),三個(gè)div已經(jīng)能夠緩慢向左移動(dòng)?,F(xiàn)在需要再開啟一個(gè)定時(shí)器B,并將A定時(shí)器裝入到B定時(shí)器中,A的定時(shí)器時(shí)間間隔應(yīng)該長于一個(gè)div完全走進(jìn)顯示框的時(shí)間,我這里設(shè)置為3秒。然后,將A定時(shí)器裝入到方法divInterval中,B定時(shí)器調(diào)用這個(gè)方法。且為了用戶體驗(yàn)效果更好,當(dāng)一個(gè)div完全走入顯示框后,應(yīng)該等待一段時(shí)間,再開是移動(dòng)。所以在LeftMove方法中,*if判斷中還需關(guān)閉moveId這個(gè)定時(shí)器*,停止此時(shí)移動(dòng)的div定時(shí)器。當(dāng)3秒不到的時(shí)間后,定時(shí)器B又會(huì)開啟一個(gè)新的定時(shí)器A。** if處添加一句代碼為: if(left<=-width){ left=(arr.length-1)*width;//當(dāng)圖片完全走出顯示框,拼接到末尾 clearInterval(moveId); } function divInterval(){ moveId=setInterval(LeftMove,10);//設(shè)置一個(gè)10毫秒定時(shí)器 } timeId=setInterval(divInterval,3000);//設(shè)置一個(gè)3秒的定時(shí)器。
到這里,輪播圖基本已經(jīng)實(shí)現(xiàn)了。然后,還需要在css樣式中為box添加overflow,將超出顯示框的div隱藏。
#box{ width:100px; height:100px; border:1px solid black; position:relative; overflow:hidden;}
然后為了解決當(dāng)鼠標(biāo)懸停在輪播圖,輪播圖停止輪播效果,需要在box上添加鼠標(biāo)移入和移出事件。開始標(biāo)簽:
<div id="box" onmouseover="stop()" onmouseout="start()">
添加js代碼:
function stop(){ clearInterval(timeId);//鼠標(biāo)停留關(guān)閉B定時(shí)器 } function start(){ clearInterval(timeId);//重新打開一個(gè)定時(shí)前,先關(guān)閉之前定時(shí)器。 timeId=setInterval(divInterval,2000);//重啟一個(gè)定時(shí)器 }
當(dāng)瀏覽器窗口切出或頁面切換到其他頁面一段時(shí)間再回來時(shí),輪播效果會(huì)有短暫加速(隨切出時(shí)間加長而加長)。主要是因?yàn)殡m然窗口切出去了,定時(shí)器依然在執(zhí)行,但頁面卻沒有將效果顯示,所以切回來后會(huì)將之前的效果顯示出來而加速輪播圖。所以添加頁面焦點(diǎn)事件:
//頁面失去焦點(diǎn)定時(shí)器停止 onblur = function(){ stop(); } //頁面獲取焦點(diǎn)時(shí)重啟定時(shí)器 onfocus = function(){ start(); }
全部代碼如下:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>輪播圖</title> <style type="text/css"> #box{ width:100px; height:100px; border:1px solid black; position:relative; overflow:hidden; } #red{ background-color:red; width:100px; } #green{ background-color:green; width:100px; } #blue{ background-color:blue; width:100px; } .slide{ width:100px; height:100px; position:absolute; } </style> <script type="text/javascript"> onload=function(){ var arr = document.getElementsByClassName("slide"); for(var i=0;i<arr.length;i++){ arr[i].style.left = i*100+"px"; } } function LeftMove(){ var arr = document.getElementsByClassName("slide");//獲取三個(gè)子div for(var i=0;i<arr.length;i++){ var left = parseFloat(arr[i].style.left); left-=2; var width = 100;//圖片的寬度 if(left<=-width){ left=(arr.length-1)*width;//當(dāng)圖片完全走出顯示框,拼接到末尾 clearInterval(moveId); } arr[i].style.left = left+"px"; } } function divInterval(){ moveId=setInterval(LeftMove,10);//設(shè)置一個(gè)10毫秒定時(shí)器 } timeId=setInterval(divInterval,2000);//設(shè)置一個(gè)3秒的定時(shí)器。 function stop(){ clearInterval(timeId); } function start(){ clearInterval(timeId); timeId=setInterval(divInterval,2000); } //頁面失去焦點(diǎn)停止 onblur = function(){ stop(); } //頁面獲取焦點(diǎn)時(shí)開始 onfocus = function(){ start(); } </script> </head> <body> <div id="box" onmouseover="stop()" onmouseout="start()"> <div id="red" class="slide"></div> <div id="green" class="slide"></div> <div id="blue" class="slide"></div> </div> </body> </html>
到此這篇關(guān)于HTML5輪播圖全代碼的文章就介紹到這了,更多相關(guān)HTML5輪播圖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!
相關(guān)文章
- 這篇文章主要介紹了HTML5+css3:3D旋轉(zhuǎn)木馬效果相冊,主要運(yùn)用了perspective和tranlateY這兩個(gè)知識(shí)點(diǎn),有需要的可以了解一下。2017-01-03
- 這篇文章主要介紹了純HTML和CSS實(shí)現(xiàn)JD輪播圖效果,需要的朋友可以參考下2018-06-01
html5+css如何實(shí)現(xiàn)中間大兩頭小的輪播效果
這篇文章主要介紹了html5+css如何實(shí)現(xiàn)中間大兩頭小的輪播效果的相關(guān)資料,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-12-06HTML+CSS+JS實(shí)現(xiàn)堆疊輪播效果的示例代碼
這篇文章主要介紹了HTML+CSS+JS實(shí)現(xiàn)堆疊輪播效果,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-08HTML+CSS實(shí)現(xiàn)全景輪播的示例代碼
本文主要介紹了HTML+CSS實(shí)現(xiàn)全景輪播的示例代碼,實(shí)現(xiàn)了一個(gè)簡單的網(wǎng)頁布局,其中包含了五個(gè)不同的盒子,每個(gè)盒子都有一個(gè)不同的背景圖片,并且它們之間有一些間距,下面就2024-02-02