jquery實(shí)現(xiàn)定時(shí)自動(dòng)輪播特效
這次的輪播圖是在上一篇文章jQuery手動(dòng)點(diǎn)擊實(shí)現(xiàn)圖片輪播特效的基礎(chǔ)上寫出來(lái)的,也就是本次展示的是手動(dòng)點(diǎn)擊輪播效果以及定時(shí)自動(dòng)輪播效果的程序,建議想連貫學(xué)習(xí)的小伙伴把我之前的文章看一看,看完后再看這篇文章~~~~
下面來(lái)看看我做的最終定時(shí)自動(dòng)輪播效果以及手動(dòng)點(diǎn)擊輪播效果:

對(duì)于上面的展示動(dòng)畫速度比較快的原因是因?yàn)槲业慕貓D軟件是綠色版,免費(fèi)的~~~你們懂得,就是卡卡的,真正的效果比這個(gè)速度慢,而且還是勻速,可以商用~~~所以上面的展示動(dòng)畫只能當(dāng)做完成效果的參考。
一、主體程序
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>輪播圖①(手動(dòng)點(diǎn)擊輪播)</title> <link type="text/css" rel="stylesheet" href="css/layout.css" /> </head> <body> <div class="slideShow"> <!--圖片布局開始--> <ul> <li><a href="#"><img src="img/picture01.jpg" /></a></li> <li><a href="#"><img src="img/picture02.jpg" /></a></li> <li><a href="#"><img src="img/picture03.jpg" /></a></li> <li><a href="#"><img src="img/picture04.jpg" /></a></li> </ul> <!--圖片布局結(jié)束--> <!--按鈕布局開始--> <div class="showNav"> <span class="active">1</span> <span>2</span> <span>3</span> <span>4</span> </div> <!--按鈕布局結(jié)束--> </div> <script src="js/jquery-1.11.3.js"></script> <script src="js/layout.js"></script> </body> </html>
額,上面的主體程序和前一篇沒(méi)有區(qū)別,未做任何修改~~~~~感興趣的可以查看第一篇文章,我本次隨筆重點(diǎn)會(huì)在Jquery程序里面
二、CSS樣式
*{
margin: 0;
padding: 0;
}
ul{
list-style: none;
}
.slideShow{
width: 346px;
height: 210px; /*其實(shí)就是圖片的高度*/
border: 1px #eeeeee solid;
margin: 100px auto;
position: relative;
overflow: hidden; /*此處需要將溢出框架的圖片部分隱藏*/
}
.slideShow ul{
width: 2000px;
position: relative; /*此處需注意relative : 對(duì)象不可層疊,但將依據(jù)left,right,top,bottom等屬性在正常文檔流中偏移位置,如果沒(méi)有這個(gè)屬性,圖片將不可左右移動(dòng)*/
}
.slideShow ul li{
float: left; /*讓四張圖片左浮動(dòng),形成并排的橫著布局,方便點(diǎn)擊按鈕時(shí)的左移動(dòng)*/
width: 346px;
}
.slideShow .showNav{ /*用絕對(duì)定位給數(shù)字按鈕進(jìn)行布局*/
position: absolute;
right: 10px;
bottom: 5px;
text-align:center;
font-size: 12px;
line-height: 20px;
}
.slideShow .showNav span{
cursor: pointer;
display: block;
float: left;
width: 20px;
height: 20px;
background: #ff5a28;
margin-left: 2px;
color: #fff;
}
.slideShow .showNav .active{
background: #b63e1a;
}
三、jQuery程序
首先說(shuō)一下定時(shí)自動(dòng)輪播的原理:
1、首先得開一個(gè)定時(shí)器,假設(shè)定時(shí)器的時(shí)間設(shè)置為2000ms,也就是2S定時(shí)器執(zhí)行一次操作
2、定時(shí)器每隔2S執(zhí)行的操作就是模擬按次序點(diǎn)擊數(shù)字按鈕,也就是觸發(fā)click事件,讓圖片左移
先來(lái)看大體效果實(shí)現(xiàn)的jQuery代碼一:
var timer=null; //定時(shí)器返回值,主要用于關(guān)閉定時(shí)器
var iNow=0; //iNow為正在展示的圖片索引值,當(dāng)用戶打開網(wǎng)頁(yè)時(shí)首先顯示第一張圖,即索引值為0
timer=setInterval(function(){ //打開定時(shí)器
iNow++; //讓圖片的索引值次序加1,這樣就可以實(shí)現(xiàn)順序輪播圖片
showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click事件
},2000); //2000為輪播的時(shí)間
上面的程序可以實(shí)現(xiàn)每隔2S圖片的輪播效果,但是輪播到最后一張圖的時(shí)候會(huì)停止,因?yàn)闆](méi)有判斷iNow是否到達(dá)最后一張圖,所以有了下面的代碼二:
var timer=null; //定時(shí)器返回值,主要用于關(guān)閉定時(shí)器
var iNow=0; //iNow為正在展示的圖片索引值,當(dāng)用戶打開網(wǎng)頁(yè)時(shí)首先顯示第一張圖,即索引值為0
timer=setInterval(function(){ //打開定時(shí)器
iNow++; //讓圖片的索引值次序加1,這樣就可以實(shí)現(xiàn)順序輪播圖片
if(iNow>showNumber.length-1){ //當(dāng)?shù)竭_(dá)最后一張圖的時(shí)候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開始
iNow=0;
}
showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
},2000); //2000為輪播的時(shí)間
所以jQuery程序的完整代碼程序如下:
$(document).ready(function(){
var slideShow=$(".slideShow"), //獲取最外層框架的名稱
ul=slideShow.find("ul"),
showNumber=slideShow.find(".showNav span"),//獲取按鈕
oneWidth=slideShow.find("ul li").eq(0).width(); //獲取每個(gè)圖片的寬度
var timer=null; //定時(shí)器返回值,主要用于關(guān)閉定時(shí)器
var iNow=0; //iNow為正在展示的圖片索引值,當(dāng)用戶打開網(wǎng)頁(yè)時(shí)首先顯示第一張圖,即索引值為0
showNumber.on("click",function(){ //為每個(gè)按鈕綁定一個(gè)點(diǎn)擊事件
$(this).addClass("active").siblings().removeClass("active"); //按鈕點(diǎn)擊時(shí)為這個(gè)按鈕添加高亮狀態(tài),并且將其他按鈕高亮狀態(tài)去掉
var index=$(this).index(); //獲取哪個(gè)按鈕被點(diǎn)擊,也就是找到被點(diǎn)擊按鈕的索引值
ul.animate({
"left":-oneWidth*iNow, //注意此處用到left屬性,所以u(píng)l的樣式里面需要設(shè)置position: relative; 讓ul左移N個(gè)圖片大小的寬度,N根據(jù)被點(diǎn)擊的按鈕索引值index確定
})
});
timer=setInterval(function(){ //打開定時(shí)器
iNow++; //讓圖片的索引值次序加1,這樣就可以實(shí)現(xiàn)順序輪播圖片
if(iNow>showNumber.length-1){ //當(dāng)?shù)竭_(dá)最后一張圖的時(shí)候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開始
iNow=0;
}
showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
},2000); //2000為輪播的時(shí)間
})
上面的注釋寫的很詳細(xì)了,主要是為了方便想學(xué)習(xí)的小伙伴看,但是實(shí)際上我寫程序不會(huì)注釋的那么詳細(xì),都是很簡(jiǎn)單的內(nèi)容啦,看到這里你可能以為jQuery程序就完了,那就大錯(cuò)特錯(cuò)了,因?yàn)樽詣?dòng)輪播效果是正確的,但是手動(dòng)點(diǎn)擊時(shí)就會(huì)出錯(cuò),我特意做了一段Gif動(dòng)畫展示出錯(cuò)的效果:

看到上面的效果你就會(huì)忽然大悟,圖片自動(dòng)輪播時(shí),你就算點(diǎn)擊按鈕它也只是附和你一下,跳轉(zhuǎn)到你點(diǎn)擊的按鈕,但是僅僅持續(xù)一會(huì)還是按它輪播的次序,不理會(huì)你點(diǎn)擊的按鈕后應(yīng)該走的輪播次序,至于原因嘛
是因?yàn)槭謩?dòng)點(diǎn)擊時(shí)index的值未賦值給定時(shí)器的圖片索引iNow,這樣iNow就無(wú)法存儲(chǔ)你點(diǎn)擊的按鈕索引值,也就是不知道你點(diǎn)擊的哪個(gè)按鈕,既然知道了原因,那么下面就需要進(jìn)行修改了。
修改完成后的jQuery程序最終版就是:
$(document).ready(function(){
var slideShow=$(".slideShow"), //獲取最外層框架的名稱
ul=slideShow.find("ul"),
showNumber=slideShow.find(".showNav span"),//獲取按鈕
oneWidth=slideShow.find("ul li").eq(0).width(); //獲取每個(gè)圖片的寬度
var timer=null; //定時(shí)器返回值,主要用于關(guān)閉定時(shí)器
var iNow=0; //iNow為正在展示的圖片索引值,當(dāng)用戶打開網(wǎng)頁(yè)時(shí)首先顯示第一張圖,即索引值為0
showNumber.on("click",function(){ //為每個(gè)按鈕綁定一個(gè)點(diǎn)擊事件
$(this).addClass("active").siblings().removeClass("active"); //按鈕點(diǎn)擊時(shí)為這個(gè)按鈕添加高亮狀態(tài),并且將其他按鈕高亮狀態(tài)去掉
var index=$(this).index(); //獲取哪個(gè)按鈕被點(diǎn)擊,也就是找到被點(diǎn)擊按鈕的索引值
iNow=index;
ul.animate({
"left":-oneWidth*iNow, //注意此處用到left屬性,所以u(píng)l的樣式里面需要設(shè)置position: relative; 讓ul左移N個(gè)圖片大小的寬度,N根據(jù)被點(diǎn)擊的按鈕索引值iNOWx確定
})
});
timer=setInterval(function(){ //打開定時(shí)器
iNow++; //讓圖片的索引值次序加1,這樣就可以實(shí)現(xiàn)順序輪播圖片
if(iNow>showNumber.length-1){ //當(dāng)?shù)竭_(dá)最后一張圖的時(shí)候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開始
iNow=0;
}
showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
},2000); //2000為輪播的時(shí)間
})
精彩專題分享:jQuery圖片輪播 JavaScript圖片輪播 Bootstrap圖片輪播
以上就是本文的全部?jī)?nèi)容,下次就為大家分享鼠標(biāo)懸浮在輪播圖上方時(shí)圖片停止輪播,鼠標(biāo)移走后圖片接著進(jìn)行輪播的代碼,不要走開。
- 12款經(jīng)典的白富美型—jquery圖片輪播插件—前端開發(fā)必備
- Jquery代碼實(shí)現(xiàn)圖片輪播效果(一)
- 原生js和jquery實(shí)現(xiàn)圖片輪播特效
- jQuery圖片輪播的具體實(shí)現(xiàn)
- 基于JQuery的實(shí)現(xiàn)圖片輪播效果(焦點(diǎn)圖)
- 原生js和jquery實(shí)現(xiàn)圖片輪播淡入淡出效果
- jquery 實(shí)現(xiàn)輪播圖詳解及實(shí)例代碼
- 利用jquery寫的左右輪播圖特效
- jQuery實(shí)現(xiàn)碎片輪播效果
- jQuery實(shí)現(xiàn)炸裂輪播效果
相關(guān)文章
jquery實(shí)現(xiàn)全屏滾動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了jquery實(shí)現(xiàn)全屏滾動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
jquery實(shí)現(xiàn)input框獲取焦點(diǎn)的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇jquery實(shí)現(xiàn)input框獲取焦點(diǎn)的簡(jiǎn)單實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-01-01
jQuery實(shí)現(xiàn)的多選框多級(jí)聯(lián)動(dòng)插件
這篇文章主要介紹了jQuery實(shí)現(xiàn)的多選框聯(lián)動(dòng)插件,需要的朋友可以參考下2014-05-05
jQuery實(shí)現(xiàn)可用于博客的動(dòng)態(tài)滑動(dòng)菜單
這篇文章主要介紹了jQuery實(shí)現(xiàn)可用于博客的動(dòng)態(tài)滑動(dòng)菜單,實(shí)例分析了jQuery操作鼠標(biāo)事件及css樣式實(shí)現(xiàn)動(dòng)態(tài)滑動(dòng)菜單的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-03-03
jQuery插件slick實(shí)現(xiàn)響應(yīng)式移動(dòng)端幻燈片圖片切換特效
jQuery插件slick是一款響應(yīng)式、適用于移動(dòng)設(shè)備觸摸屏、可滑動(dòng)顯示的jQuery幻燈片插件。該幻燈片插件可以設(shè)置多種顯示效果,可以自動(dòng)播放,是一款移動(dòng)優(yōu)先的jQuery幻燈片插件。2015-04-04
簡(jiǎn)單實(shí)現(xiàn)限制uploadify上傳個(gè)數(shù)
本文給大家分享的是在使用uploadify上傳文件或者圖片的時(shí)候,如何做到限制上傳個(gè)數(shù)的方法,十分的簡(jiǎn)單方便實(shí)用,有需要的小伙伴可以參考下。2015-11-11
Jquery EasyUI實(shí)現(xiàn)treegrid上顯示checkbox并取選定值的方法
這篇文章主要介紹了Jquery EasyUI實(shí)現(xiàn)treegrid上顯示checkbox并取選定值的方法的相關(guān)資料,需要的朋友可以參考下2016-04-04

