jquery實(shí)現(xiàn)鼠標(biāo)懸浮停止輪播特效
本文實(shí)例講述了jquery實(shí)現(xiàn)鼠標(biāo)懸浮停止輪播特效代碼。分享給大家供大家參考,具體如下:
運(yùn)行效果截圖如下:

具體代碼如下:
一、主體程序
<!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"> <!--圖片布局開(kāi)始--> <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é)束--> <!--按鈕布局開(kāi)始--> <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>
二、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ō)一下鼠標(biāo)懸浮圖片輪播停止的原理:
- 1、當(dāng)鼠標(biāo)懸浮在框架上方時(shí),清除定時(shí)器即用clearInterval(timer)關(guān)閉定時(shí)器,使自動(dòng)輪播停止
- 2、當(dāng)鼠標(biāo)離開(kāi)框架上方時(shí),重新啟動(dòng)定時(shí)器
- 3、鼠標(biāo)的懸浮和離開(kāi)借助于hover函數(shù)
hover(over,out)一個(gè)模仿懸停事件(鼠標(biāo)移動(dòng)到一個(gè)對(duì)象上面及移出這個(gè)對(duì)象)的方法。這是一個(gè)自定義的方法,它為頻繁使用的任務(wù)提供了一種“保持在其中”的狀態(tài)。
參數(shù):
over (Function) : 鼠標(biāo)移到元素上要觸發(fā)的函數(shù)。
out (Function): 鼠標(biāo)移出元素要觸發(fā)的函數(shù)。
下面來(lái)看jQuery程序:
$(document).ready(function(){
var slideShow=$(".slideShow"), //獲取最外層框架的名稱(chēng)
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)用戶(hù)打開(kāi)網(wǎng)頁(yè)時(shí)首先顯示第一張圖,即索引值為0
/*手動(dòng)點(diǎn)擊按鈕進(jìn)行圖片輪播代碼開(kāi)始*/
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)擊的按鈕索引值iNow確定
})
});
/*手動(dòng)點(diǎn)擊按鈕進(jìn)行圖片輪播代碼結(jié)束*/
/*定時(shí)自動(dòng)輪播圖片代碼開(kāi)始*/
timer=setInterval(function(){ //打開(kāi)定時(shí)器
iNow++; //讓圖片的索引值次序加1,這樣就可以實(shí)現(xiàn)順序輪播圖片
if(iNow>showNumber.length-1){ //當(dāng)?shù)竭_(dá)最后一張圖的時(shí)候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開(kāi)始
iNow=0;
}
showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
},2000); //2000為輪播的時(shí)間
/*定時(shí)自動(dòng)輪播圖片代碼結(jié)束*/
/*鼠標(biāo)懸浮圖片停止輪播代碼開(kāi)始*/
slideShow.hover(
function(){
clearInterval(timer);
},function(){
timer=setInterval(function(){ //打開(kāi)定時(shí)器
iNow++; //讓圖片的索引值次序加1,這樣就可以實(shí)現(xiàn)順序輪播圖片
if(iNow>showNumber.length-1){ //當(dāng)?shù)竭_(dá)最后一張圖的時(shí)候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開(kāi)始
iNow=0;
}
showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
},2000); //2000為輪播的時(shí)間
}
);
/*鼠標(biāo)懸浮圖片停止輪播代碼結(jié)束*/
})
從上圖可以看出開(kāi)啟定時(shí)器的代碼是重復(fù)的,所以這里可以定義一個(gè)自動(dòng)播放的函數(shù)autoPlay()來(lái)精簡(jiǎn)代碼,經(jīng)過(guò)精簡(jiǎn)后的代碼如下:
/*定時(shí)自動(dòng)輪播圖片代碼開(kāi)始*/
function autoPlay(){
timer=setInterval(function(){ //打開(kāi)定時(shí)器
iNow++; //讓圖片的索引值次序加1,這樣就可以實(shí)現(xiàn)順序輪播圖片
if(iNow>showNumber.length-1){ //當(dāng)?shù)竭_(dá)最后一張圖的時(shí)候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開(kāi)始
iNow=0;
}
showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
},2000); //2000為輪播的時(shí)間
}
autoPlay();
/*定時(shí)自動(dòng)輪播圖片代碼結(jié)束*/
定義完成后不要忘記調(diào)用這個(gè)函數(shù),即autoPlay();
那么最終版的jQuery程序如下:
$(document).ready(function(){
var slideShow=$(".slideShow"), //獲取最外層框架的名稱(chēng)
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)用戶(hù)打開(kāi)網(wǎng)頁(yè)時(shí)首先顯示第一張圖,即索引值為0
/*手動(dòng)點(diǎn)擊按鈕進(jìn)行圖片輪播代碼開(kāi)始*/
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)擊的按鈕索引值iNow確定
})
});
/*手動(dòng)點(diǎn)擊按鈕進(jìn)行圖片輪播代碼結(jié)束*/
/*定時(shí)自動(dòng)輪播圖片代碼開(kāi)始*/
function autoPlay(){
timer=setInterval(function(){ //打開(kāi)定時(shí)器
iNow++; //讓圖片的索引值次序加1,這樣就可以實(shí)現(xiàn)順序輪播圖片
if(iNow>showNumber.length-1){ //當(dāng)?shù)竭_(dá)最后一張圖的時(shí)候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開(kāi)始
iNow=0;
}
showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
},2000); //2000為輪播的時(shí)間
}
autoPlay();
/*定時(shí)自動(dòng)輪播圖片代碼結(jié)束*/
/*鼠標(biāo)懸浮圖片停止輪播代碼開(kāi)始*/
slideShow.hover(
function(){
clearInterval(timer);
},autoPlay
);
/*鼠標(biāo)懸浮圖片停止輪播代碼結(jié)束*/
})
以上就是本文的全部?jī)?nèi)容,大家可以結(jié)合下面這兩篇文章進(jìn)行學(xué)習(xí):
文章一:jQuery手動(dòng)點(diǎn)擊實(shí)現(xiàn)圖片輪播特效
文章二:jquery實(shí)現(xiàn)定時(shí)自動(dòng)輪播特效
精彩專(zhuān)題分享:jQuery圖片輪播 JavaScript圖片輪播 Bootstrap圖片輪播
希望本文所述對(duì)大家學(xué)習(xí)jQuery程序設(shè)計(jì)有所幫助。
- jQuery實(shí)現(xiàn)鼠標(biāo)拖拽登錄框移動(dòng)效果
- jQuery實(shí)現(xiàn)百度登錄框的動(dòng)態(tài)切換效果
- JQuery Mobile 彈出式登錄框的實(shí)現(xiàn)方法
- jquery中dom操作和事件的實(shí)例學(xué)習(xí) 仿yahoo郵箱登錄框的提示效果
- jquery鼠標(biāo)放上去顯示懸浮層即彈出定位的div層
- jquery懸浮提示框完整實(shí)例
- jquery-tips懸浮提示插件分享
- js點(diǎn)擊出現(xiàn)懸浮窗效果不使用JQuery插件
- 使用jQuery UI的tooltip函數(shù)修飾title屬性的氣泡懸浮框
- jquery+CSS實(shí)現(xiàn)懸浮登錄框遮罩
相關(guān)文章
jQuery實(shí)現(xiàn)百度登錄框的動(dòng)態(tài)切換效果
這篇文章主要介紹了jQuery實(shí)現(xiàn)百度登錄框的動(dòng)態(tài)切換效果,需要的朋友可以參考下2017-04-04
JQuery彈出炫麗對(duì)話(huà)框的同時(shí)讓背景變灰色
這篇文章主要介紹JQuery實(shí)現(xiàn)彈出炫麗對(duì)話(huà)框的同時(shí)讓背景變灰色效果,需要的朋友可以參考下2014-05-05
基于jquery實(shí)現(xiàn)的服務(wù)器驗(yàn)證控件的啟用和禁用代碼
用戶(hù)點(diǎn)擊下一步時(shí),不對(duì)Display=none的新增區(qū)域表單進(jìn)行驗(yàn)證,需要在用戶(hù)點(diǎn)擊“取消增加時(shí)”,禁用服務(wù)器驗(yàn)證控件。反之,啟用服務(wù)器驗(yàn)證控件。2010-04-04
jquery實(shí)現(xiàn)點(diǎn)擊a鏈接,跳轉(zhuǎn)之后,該a鏈接處顯示背景色的方法
下面小編就為大家分享一篇jquery實(shí)現(xiàn)點(diǎn)擊a鏈接,跳轉(zhuǎn)之后,該a鏈接處顯示背景色的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01
jQuery判斷郵箱格式對(duì)錯(cuò)實(shí)例代碼講解
本文通過(guò)實(shí)例代碼給大家講解了基于jquery判斷郵箱格式對(duì)錯(cuò),非常實(shí)用,具有參考借鑒價(jià)值,需要的的朋友參考下吧2017-04-04
jQuery如何獲取同一個(gè)類(lèi)標(biāo)簽的所有值(默認(rèn)無(wú)法獲取)
jQuery總是只返回第一個(gè)類(lèi)標(biāo)簽的值,所以無(wú)法達(dá)到我們的要求,那么jQuery如何獲取同一個(gè)類(lèi)標(biāo)簽的所有的值,下面與大家分享方法2014-09-09
jquery tree 可編輯節(jié)點(diǎn)實(shí)現(xiàn)代碼(jquery一句話(huà)節(jié)點(diǎn)菜單)
jquery tree 可編輯節(jié)點(diǎn),實(shí)現(xiàn)的三級(jí)菜單實(shí)現(xiàn)代碼,這里我們將為大家準(zhǔn)備了兩個(gè)。一個(gè)是鋒利的jquery中的一句話(huà)導(dǎo)航菜單實(shí)現(xiàn)代碼。非常不錯(cuò)。2009-11-11

