輪播圖原理大概是這樣的,假定三張圖片需要做輪播效果,首先需要將這三張圖片并列放置,然后將這個整體并列向左移動,每當(dāng)一張圖片完整的從顯示框走出,則將這張圖片放置到最后面,循環(huán)往復(fù)就可以實現(xiàn)圖片向左(或一個方向)移動。然后,需要有兩個定時器,一個定時器A控制三張圖片整體左移速度,另一個定時器B控制每當(dāng)一張完整的圖片走進(jìn)這個顯示框就等待一到兩秒得到更好的用戶體驗。
我這里用三個div框當(dāng)作輪播圖來演示。
在html的body中添加一個div作為顯示框,然后在這個div內(nèi)部添加三個子div作為圖片顯示。代碼如下:
<div id="box">
<div id="red" class="slide"></div>
<div id="green" class="slide"></div>
<div id="blue" class="slide"></div>
</div>
頭部添加css樣式:
此時網(wǎng)頁中應(yīng)該是有一個黑色顯示框div,內(nèi)部有紅、綠、藍(lán)三個div框,三個框從上到下排列。
第一步,需要將三張圖片都并列顯示。
要實現(xiàn)將div挪動,且div比較方便控制每時每刻的位置(移動),只能使用相對定位,且為方便,三個子div位置移動應(yīng)該是相對box,所以box應(yīng)該作為相對的參照點。分別為box和slide代碼添加position屬性:
#box{
width:100px;
height:100px;
border:1px solid black;
position:relative;
}
.slide{
width:100px;
height:100px;
position:absolute;
}
為整個頁面添加onload加載完成事件,當(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)頁面加載完全,三個div應(yīng)該并列在一起。
接下來,需要實現(xiàn)將這三個div整體向左移動,使用定時器,即前面的定時器A。*onload同級下面添加如下代碼:
function LeftMove(){
var arr = document.getElementsByClassName("slide");//獲取三個子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è)置一個10毫秒定時器,并給自己取名
**此時,三個div已經(jīng)能夠緩慢向左移動?,F(xiàn)在需要再開啟一個定時器B,并將A定時器裝入到B定時器中,A的定時器時間間隔應(yīng)該長于一個div完全走進(jìn)顯示框的時間,我這里設(shè)置為3秒。然后,將A定時器裝入到方法divInterval中,B定時器調(diào)用這個方法。且為了用戶體驗效果更好,當(dāng)一個div完全走入顯示框后,應(yīng)該等待一段時間,再開是移動。所以在LeftMove方法中,*if判斷中還需關(guān)閉moveId這個定時器*,停止此時移動的div定時器。當(dāng)3秒不到的時間后,定時器B又會開啟一個新的定時器A。**
if處添加一句代碼為:
if(left<=-width){
left=(arr.length-1)*width;//當(dāng)圖片完全走出顯示框,拼接到末尾
clearInterval(moveId);
}
function divInterval(){
moveId=setInterval(LeftMove,10);//設(shè)置一個10毫秒定時器
}
timeId=setInterval(divInterval,3000);//設(shè)置一個3秒的定時器。
到這里,輪播圖基本已經(jīng)實現(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定時器
}
function start(){
clearInterval(timeId);//重新打開一個定時前,先關(guān)閉之前定時器。
timeId=setInterval(divInterval,2000);//重啟一個定時器
}
當(dāng)瀏覽器窗口切出或頁面切換到其他頁面一段時間再回來時,輪播效果會有短暫加速(隨切出時間加長而加長)。主要是因為雖然窗口切出去了,定時器依然在執(zhí)行,但頁面卻沒有將效果顯示,所以切回來后會將之前的效果顯示出來而加速輪播圖。所以添加頁面焦點事件:
//頁面失去焦點定時器停止
onblur = function(){
stop();
}
//頁面獲取焦點時重啟定時器
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");//獲取三個子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è)置一個10毫秒定時器
}
timeId=setInterval(divInterval,2000);//設(shè)置一個3秒的定時器。
function stop(){
clearInterval(timeId);
}
function start(){
clearInterval(timeId);
timeId=setInterval(divInterval,2000);
}
//頁面失去焦點停止
onblur = function(){
stop();
}
//頁面獲取焦點時開始
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)文章,希望大家以后多多支持腳本之家!