国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

jQuery隊列控制方法詳解queue()/dequeue()/clearQueue()

2019-11-21 00:04:28
字體:
來源:轉載
供稿:網友

先解釋一下這組方法各自的含義.
queue(name,[callback]): 當只傳入一個參數時, 它返回并指向第一個匹配元素的隊列(將是一個函數數組,隊列名默認是fx); 當有兩個參數傳入時, 第一個參數還是默認為fx的的隊列名, 第二個參數又分兩種情況, 當第二個參數是一個函數時, 它將在匹配的元素的隊列最后添加一個函數. 當第二個參數是一個函數數組時,它將匹配元素的隊列用新的一個隊列來代替(函數數組).可能, 這個理解起來有點暈, 稍后, 后面會有點此查看DEMO.

dequeue(name): 這個好理解, 就是從隊列最前端移除一個隊列函數, 并執行它.
clearQueue([queueName]):這是1.4新增的方法. 清空對象上尚未執行的所有隊列. 參數可選,默認為fx. 但個人覺得這個方法沒多大用, 用queue()方法傳入兩個參數的第二種參數即可實現clearQueue方法.
現在, 我們要實現這樣一個效果, 有標有1至7的數字方塊, 要求這七個方塊自左到右依次下落.點此查看DEMO


css與html部分我就不貼出來了,DEMO演示中有. 若按常規做法, 可能需要用如下jQ代碼來實現:

$('.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!')							});						});					});				});			});		});	});

嗯, 沒錯, 效果很完美的呈現給出來了, 但這種暈眩的代碼, 你能忍受嗎? 即便可以忍受, 如果此時, 你想調換一個某個的執行順序, 比如, 你想讓5落下后再開始下落3, 或者新加8至15八個方塊, 怎么辦? 重寫嗎? 在里面小心冀冀的改嗎? 顯然, 我們需要另外一種列簡明便捷的方法來實現這個效果, 那就是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();

這樣一來, 看起來是不是簡明多了. 如何實現?
1. 新建一個數組,把動畫函數依次放進去(這樣更改順序,新加動畫是不是方便多了?);
2. 用queue將這組動畫函數數組加入到slideList隊列中;
3. 用dequeue取出slideList隊列中第一個函數, 并執行它;
4. 初始執行第一個函數.
DEMO演示中也有詳解的注釋, 如果上面的說明還看不明白,請看源碼.
至于clearQueue()方法,就不多說了, 演示中停止按鈕調用的就是clearQueue()方法,當然你還可以用queue()方法直接將現在的函數列隊替換成[]空數組實現(個人比較推薦空數組替換.,更直觀).

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 祥云县| 临漳县| 仙桃市| 太仆寺旗| 松江区| 佛学| 喜德县| 昆山市| 平乐县| 建始县| 宝山区| 蓝田县| 永安市| 中方县| 登封市| 丹阳市| 衡阳县| 利川市| 新郑市| 新密市| 平阴县| 万荣县| 中山市| 荔浦县| 凌源市| 剑河县| 互助| 衡南县| 石棉县| 黄大仙区| 柳河县| 临沧市| 东乌珠穆沁旗| 镇安县| 定安县| 江陵县| 平山县| 成都市| 亳州市| 渝中区| 沙田区|