jQuery隊(duì)列控制方法詳解queue()/dequeue()/clearQueue()
先解釋一下這組方法各自的含義.
queue(name,[callback]): 當(dāng)只傳入一個(gè)參數(shù)時(shí), 它返回并指向第一個(gè)匹配元素的隊(duì)列(將是一個(gè)函數(shù)數(shù)組,隊(duì)列名默認(rèn)是fx); 當(dāng)有兩個(gè)參數(shù)傳入時(shí), 第一個(gè)參數(shù)還是默認(rèn)為fx的的隊(duì)列名, 第二個(gè)參數(shù)又分兩種情況, 當(dāng)?shù)诙€(gè)參數(shù)是一個(gè)函數(shù)時(shí), 它將在匹配的元素的隊(duì)列最后添加一個(gè)函數(shù). 當(dāng)?shù)诙€(gè)參數(shù)是一個(gè)函數(shù)數(shù)組時(shí),它將匹配元素的隊(duì)列用新的一個(gè)隊(duì)列來(lái)代替(函數(shù)數(shù)組).可能, 這個(gè)理解起來(lái)有點(diǎn)暈, 稍后, 后面會(huì)有點(diǎn)此查看DEMO.
dequeue(name): 這個(gè)好理解, 就是從隊(duì)列最前端移除一個(gè)隊(duì)列函數(shù), 并執(zhí)行它.
clearQueue([queueName]):這是1.4新增的方法. 清空對(duì)象上尚未執(zhí)行的所有隊(duì)列. 參數(shù)可選,默認(rèn)為fx. 但個(gè)人覺得這個(gè)方法沒多大用, 用queue()方法傳入兩個(gè)參數(shù)的第二種參數(shù)即可實(shí)現(xiàn)clearQueue方法.
現(xiàn)在, 我們要實(shí)現(xiàn)這樣一個(gè)效果, 有標(biāo)有1至7的數(shù)字方塊, 要求這七個(gè)方塊自左到右依次下落.點(diǎn)此查看DEMO
css與html部分我就不貼出來(lái)了,DEMO演示中有. 若按常規(guī)做法, 可能需要用如下jQ代碼來(lái)實(shí)現(xiàn):
$('.one').delay(500).animate({top:'+=270px'},500,function(){ $('.two').delay(500).animate({top:'+=270px'},500,function(){ $('.three').delay(500).animate({top:'+=270px'},500,function(){ $('.four').delay(500).animate({top:'+=270px'},500,function(){ $('.five').delay(500).animate({top:'+=270px'},500,function(){ $('.six').delay(500).animate({top:'+=270px'},500,function(){ $('.seven').animate({top:'+=270px'},500,function(){ alert('按序落體運(yùn)動(dòng)結(jié)束! Yeah!') }); }); }); }); }); }); });
嗯, 沒錯(cuò), 效果很完美的呈現(xiàn)給出來(lái)了, 但這種暈眩的代碼, 你能忍受嗎? 即便可以忍受, 如果此時(shí), 你想調(diào)換一個(gè)某個(gè)的執(zhí)行順序, 比如, 你想讓5落下后再開始下落3, 或者新加8至15八個(gè)方塊, 怎么辦? 重寫嗎? 在里面小心冀冀的改嗎? 顯然, 我們需要另外一種列簡(jiǎn)明便捷的方法來(lái)實(shí)現(xiàn)這個(gè)效果, 那就是jQuery隊(duì)列控制方法.請(qǐng)看如下代碼:
var _slideFun=[ function(){$('.one').delay(500).animate({top:'+=270px'},500,_takeOne);}, function(){$('.two').delay(300).animate({top:'+=270px'},500,_takeOne);}, function(){$('.three').delay(300).animate({top:'+=270px'},500,_takeOne);}, function(){$('.four').delay(300).animate({top:'+=270px'},500,_takeOne);}, function(){$('.five').delay(300).animate({top:'+=270px'},500,_takeOne);}, function(){$('.six').delay(300).animate({top:'+=270px'},500,_takeOne);}, function(){$('.seven').delay(300).animate({top:'+=270px'},500,function(){ alert('按序落體運(yùn)動(dòng)結(jié)束! Yeah!'); });} ]; $('#demo').queue('slideList',_slideFun); var _takeOne=function(){ $('#demo').dequeue('slideList'); }; _takeOne();
這樣一來(lái), 看起來(lái)是不是簡(jiǎn)明多了. 如何實(shí)現(xiàn)?
1. 新建一個(gè)數(shù)組,把動(dòng)畫函數(shù)依次放進(jìn)去(這樣更改順序,新加動(dòng)畫是不是方便多了?);
2. 用queue將這組動(dòng)畫函數(shù)數(shù)組加入到slideList隊(duì)列中;
3. 用dequeue取出slideList隊(duì)列中第一個(gè)函數(shù), 并執(zhí)行它;
4. 初始執(zhí)行第一個(gè)函數(shù).
DEMO演示中也有詳解的注釋, 如果上面的說(shuō)明還看不明白,請(qǐng)看源碼.
至于clearQueue()方法,就不多說(shuō)了, 演示中停止按鈕調(diào)用的就是clearQueue()方法,當(dāng)然你還可以用queue()方法直接將現(xiàn)在的函數(shù)列隊(duì)替換成[]空數(shù)組實(shí)現(xiàn)(個(gè)人比較推薦空數(shù)組替換.,更直觀).
- jQuery中queue()方法用法實(shí)例
- jquery隊(duì)列queue與原生模仿其實(shí)現(xiàn)方法分享
- jQuery中隊(duì)列queue()函數(shù)的實(shí)例教程
- jQuery 事件隊(duì)列調(diào)整方法
- jquery隊(duì)列函數(shù)用法實(shí)例
- 用隊(duì)列模擬jquery的動(dòng)畫算法實(shí)例
- 利用Jquery隊(duì)列實(shí)現(xiàn)根據(jù)輸入數(shù)量顯示的動(dòng)畫
- jQuery使用動(dòng)畫隊(duì)列自定義動(dòng)畫操作示例
- JQuery中queue方法用法示例
相關(guān)文章
jQuery判斷網(wǎng)頁(yè)是否已經(jīng)滾動(dòng)到瀏覽器底部的實(shí)現(xiàn)方法
最近做項(xiàng)目遇到這樣的需求,要求基于jq判斷網(wǎng)頁(yè)是否已經(jīng)滾動(dòng)到瀏覽器底部了,下面小編給大家分享實(shí)例代碼,需要的朋友參考下吧2017-10-10jquery實(shí)現(xiàn)上傳文件大小類型的驗(yàn)證例子(推薦)
下面小編就為大家?guī)?lái)一篇jquery實(shí)現(xiàn)上傳文件大小類型的驗(yàn)證例子(推薦)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨想過(guò)來(lái)看看吧2016-06-06基于jQuery實(shí)現(xiàn)的設(shè)置文本區(qū)域的光標(biāo)位置
之前做一個(gè)代碼提示的功能涉及到在文本框中插入文本的操作,需要獲得當(dāng)前光標(biāo)位置插入文本,本文章向大家介紹jQuery如何設(shè)置文本區(qū)域的光標(biāo)位置,需要的朋友可以參考一下2018-06-06jQuery實(shí)現(xiàn)淡入淡出二級(jí)下拉導(dǎo)航菜單的方法
這篇文章主要介紹了jQuery實(shí)現(xiàn)淡入淡出二級(jí)下拉導(dǎo)航菜單的方法,涉及jquery簡(jiǎn)單操作頁(yè)面元素展開與隱藏的實(shí)現(xiàn)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-08-08jquery刪除數(shù)據(jù)記錄時(shí)的彈出提示效果
這篇文章主要介紹了jquery實(shí)現(xiàn)的刪除數(shù)據(jù)記錄時(shí)的彈出提示效果,需要的朋友可以參考下2014-05-05簡(jiǎn)單的jquery左側(cè)導(dǎo)航欄和頁(yè)面選中效果
這篇文章主要介紹一個(gè)簡(jiǎn)單的jquery左側(cè)導(dǎo)航欄和頁(yè)面選中效果,此功能需引用jquery,需要的朋友可以參考下2014-08-08Jquery加載時(shí)從后臺(tái)讀取數(shù)據(jù)綁定到dropdownList實(shí)例
從后臺(tái)讀取數(shù)據(jù)綁定到dropdownList,option選項(xiàng)value動(dòng)態(tài)賦值,具體實(shí)現(xiàn)如下,感興趣的朋友可以參考下哈2013-06-06基于Jquery的表格隔行換色,移動(dòng)換色,點(diǎn)擊換色插件
希望能和大家一起交流學(xué)習(xí)。先放上去一個(gè)上周學(xué)習(xí)的一個(gè)jquery插件,基于Jquery的表格隔行換色,移動(dòng)換色,點(diǎn)擊換色插件。2010-12-12jQuery實(shí)現(xiàn)checkbox的簡(jiǎn)單操作
這篇文章主要介紹了jQuery實(shí)現(xiàn)checkbox的簡(jiǎn)單操作,對(duì)復(fù)選框組的全選、全不選、不全選,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11