jQuery帶控制按鈕輪播圖插件
帶控制按鈕(點(diǎn)擊移動(dòng)到指定圖片)的jQuery輪播圖插件
效果圖
當(dāng)點(diǎn)擊下方按鈕時(shí),輪播動(dòng)畫會(huì)停止,按鈕所對(duì)應(yīng)的圖片在規(guī)定時(shí)間范圍內(nèi)移動(dòng)出現(xiàn),這一動(dòng)作結(jié)束后再從當(dāng)前圖片開始繼續(xù)輪播動(dòng)畫

$.fn.slider = function(){
//輪播圖變量
var $ul =this; //在jQuery原型方法中,this就指的調(diào)用該方法的jQuery對(duì)象
var $lis = $ul.children();//返回所有的直接子標(biāo)簽
var imgwidth = $lis.width();
//設(shè)置列表的寬度
$ul.width(imgwidth*$lis.size());//size獲取元素的個(gè)數(shù)
//獲取所有的方塊按鈕
var $buttons = $('.nav li');
console.log($buttons)
console.log($lis.size())
//設(shè)置下標(biāo)
var index =0;//當(dāng)前圖片和按鈕下標(biāo)
var timer = -1;//用于保存定時(shí)器id,方便停止
//調(diào)用延時(shí)定時(shí)器
timer= setTimeout(move,2000);//間隔2s移動(dòng)一次圖片
//處理圖片列表移動(dòng),以及使用延時(shí)定時(shí)器來模擬間隔定時(shí)器
function move(){
//獲取ul當(dāng)前的margin-left
var left =parseInt( $ul.css('margin-left'));
//當(dāng)ul列表移動(dòng)到最后一張時(shí),直接設(shè)置margin-left=0px,否則繼續(xù)移動(dòng)
if(left>(-1)*(imgwidth*($lis.size()-1))){
$ul.animate({'margin-left':`-=${imgwidth}px`},1500);
index++;//當(dāng)前下標(biāo)加1
}else{
$ul.css('margin-left','0px');
index=0;//下標(biāo)為0
}
//根據(jù)index來設(shè)置按鈕樣式
//如果是最后一張,那么提前回到第一張
if(index <$buttons.size()){
$buttons.eq(index).addClass('active').siblings().removeClass('active');
}else{
$buttons.eq(0).addClass('active').siblings().removeClass('active');
}
timer = setTimeout(move,2000);
}
// 點(diǎn)擊按鈕
$buttons.click(function(){
//$(this) 訪問當(dāng)前被點(diǎn)擊的按鈕
var i = $(this).index();//獲取被點(diǎn)擊按鈕的下標(biāo)
if(i==index){
return;//提前終止
}
//停止未執(zhí)行的定時(shí)器
if(timer!=-1){
clearTimeout(timer);
}
//移動(dòng)之前把未執(zhí)行的動(dòng)畫暫停掉
$ul.stop();
//移動(dòng)
$ul.animate({'margin-left':`-${i*imgwidth}px`},1500,function(){
timer = setTimeout(move,2000);
});
//移動(dòng)之后改變按鈕狀態(tài)
$buttons.eq(i).addClass('active').siblings().removeClass('active');
// 更新當(dāng)前圖片下標(biāo)
index=i;
});
}
精彩專題分享:jQuery圖片輪播 JavaScript圖片輪播 Bootstrap圖片輪播
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
淺談原生JS實(shí)現(xiàn)jQuery的animate()動(dòng)畫示例
本篇文章主要介紹了淺談原生JS實(shí)現(xiàn)jQuery的animate()動(dòng)畫示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-03-03
jquery二級(jí)目錄選中當(dāng)前頁的css樣式
下面小編就為大家?guī)硪黄猨query二級(jí)目錄選中當(dāng)前頁的css樣式。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-12-12
jquery實(shí)現(xiàn)的橫向二級(jí)導(dǎo)航效果代碼
這篇文章主要介紹了jquery實(shí)現(xiàn)的橫向二級(jí)導(dǎo)航效果代碼,可實(shí)現(xiàn)鼠標(biāo)滑過導(dǎo)航出現(xiàn)下拉菜單切換的效果,非常簡潔自然,涉及jquery鼠標(biāo)hover事件及頁面元素樣式的動(dòng)態(tài)改變技巧,需要的朋友可以參考下2015-08-08
基于jQuery選擇器之表單對(duì)象屬性篩選選擇器的實(shí)例
下面小編就為大家?guī)硪黄猨Query選擇器之表單對(duì)象屬性篩選選擇器實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-09-09
基于cookie實(shí)現(xiàn)zTree樹刷新后展開狀態(tài)不變
這篇文章主要為大家詳細(xì)介紹了如何基于cookie實(shí)現(xiàn)zTree樹刷新后,展開狀態(tài)不變,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02
jQuery插件HighCharts實(shí)現(xiàn)的2D對(duì)數(shù)餅圖效果示例【附demo源碼下載】
這篇文章主要介紹了jQuery插件HighCharts實(shí)現(xiàn)的2D對(duì)數(shù)餅圖效果,結(jié)合實(shí)例形式分析了jQuery圖形插件HighCharts繪制2D對(duì)數(shù)餅圖的具體實(shí)現(xiàn)步驟與相關(guān)操作技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-03-03
jQuery+vue.js實(shí)現(xiàn)的多選下拉列表功能示例
這篇文章主要介紹了jQuery+vue.js實(shí)現(xiàn)的多選下拉列表功能,涉及jQuery+vue.js數(shù)據(jù)綁定及事件響應(yīng)相關(guān)操作技巧,需要的朋友可以參考下2019-01-01

