jQuery隊列控制方法詳解queue()/dequeue()/clearQueue()
先解釋一下這組方法各自的含義.
queue(name,[callback]): 當只傳入一個參數(shù)時, 它返回并指向第一個匹配元素的隊列(將是一個函數(shù)數(shù)組,隊列名默認是fx); 當有兩個參數(shù)傳入時, 第一個參數(shù)還是默認為fx的的隊列名, 第二個參數(shù)又分兩種情況, 當?shù)诙€參數(shù)是一個函數(shù)時, 它將在匹配的元素的隊列最后添加一個函數(shù). 當?shù)诙€參數(shù)是一個函數(shù)數(shù)組時,它將匹配元素的隊列用新的一個隊列來代替(函數(shù)數(shù)組).可能, 這個理解起來有點暈, 稍后, 后面會有點此查看DEMO.
dequeue(name): 這個好理解, 就是從隊列最前端移除一個隊列函數(shù), 并執(zhí)行它.
clearQueue([queueName]):這是1.4新增的方法. 清空對象上尚未執(zhí)行的所有隊列. 參數(shù)可選,默認為fx. 但個人覺得這個方法沒多大用, 用queue()方法傳入兩個參數(shù)的第二種參數(shù)即可實現(xiàn)clearQueue方法.
現(xiàn)在, 我們要實現(xiàn)這樣一個效果, 有標有1至7的數(shù)字方塊, 要求這七個方塊自左到右依次下落.點此查看DEMO
css與html部分我就不貼出來了,DEMO演示中有. 若按常規(guī)做法, 可能需要用如下jQ代碼來實現(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('按序落體運動結束! Yeah!') }); }); }); }); }); }); });
嗯, 沒錯, 效果很完美的呈現(xiàn)給出來了, 但這種暈眩的代碼, 你能忍受嗎? 即便可以忍受, 如果此時, 你想調(diào)換一個某個的執(zhí)行順序, 比如, 你想讓5落下后再開始下落3, 或者新加8至15八個方塊, 怎么辦? 重寫嗎? 在里面小心冀冀的改嗎? 顯然, 我們需要另外一種列簡明便捷的方法來實現(xiàn)這個效果, 那就是jQuery隊列控制方法.請看如下代碼:
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('按序落體運動結束! Yeah!'); });} ]; $('#demo').queue('slideList',_slideFun); var _takeOne=function(){ $('#demo').dequeue('slideList'); }; _takeOne();
這樣一來, 看起來是不是簡明多了. 如何實現(xiàn)?
1. 新建一個數(shù)組,把動畫函數(shù)依次放進去(這樣更改順序,新加動畫是不是方便多了?);
2. 用queue將這組動畫函數(shù)數(shù)組加入到slideList隊列中;
3. 用dequeue取出slideList隊列中第一個函數(shù), 并執(zhí)行它;
4. 初始執(zhí)行第一個函數(shù).
DEMO演示中也有詳解的注釋, 如果上面的說明還看不明白,請看源碼.
至于clearQueue()方法,就不多說了, 演示中停止按鈕調(diào)用的就是clearQueue()方法,當然你還可以用queue()方法直接將現(xiàn)在的函數(shù)列隊替換成[]空數(shù)組實現(xiàn)(個人比較推薦空數(shù)組替換.,更直觀).
相關文章
jQuery判斷網(wǎng)頁是否已經(jīng)滾動到瀏覽器底部的實現(xiàn)方法
最近做項目遇到這樣的需求,要求基于jq判斷網(wǎng)頁是否已經(jīng)滾動到瀏覽器底部了,下面小編給大家分享實例代碼,需要的朋友參考下吧2017-10-10jquery實現(xiàn)上傳文件大小類型的驗證例子(推薦)
下面小編就為大家?guī)硪黄猨query實現(xiàn)上傳文件大小類型的驗證例子(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨想過來看看吧2016-06-06基于jQuery實現(xiàn)的設置文本區(qū)域的光標位置
之前做一個代碼提示的功能涉及到在文本框中插入文本的操作,需要獲得當前光標位置插入文本,本文章向大家介紹jQuery如何設置文本區(qū)域的光標位置,需要的朋友可以參考一下2018-06-06Jquery加載時從后臺讀取數(shù)據(jù)綁定到dropdownList實例
從后臺讀取數(shù)據(jù)綁定到dropdownList,option選項value動態(tài)賦值,具體實現(xiàn)如下,感興趣的朋友可以參考下哈2013-06-06