jQuery 源碼分析筆記(7) Queue
更新時(shí)間:2011年06月19日 23:57:13 作者:
queue是用來(lái)維護(hù)函數(shù)隊(duì)列的。比較常用的是queue(queueName, callback);其中queueName缺省是fn,即標(biāo)準(zhǔn)函數(shù)隊(duì)列。
每個(gè)Element可以擁有多個(gè)隊(duì)列,但是基本上都只使用到一個(gè),即默認(rèn)的fn隊(duì)列。隊(duì)列允許一系列函數(shù)被異步地調(diào)用而不會(huì)阻塞程序。例如:$("#foo").slideUp().fadeIn();其實(shí)這個(gè)就是我們大家常用的鏈?zhǔn)秸{(diào)用,實(shí)際上這是一個(gè)Queue。所以隊(duì)列和Deferred地位類似,是一個(gè)內(nèi)部使用的基礎(chǔ)設(shè)施。當(dāng)slideUp運(yùn)行時(shí),fadeIn被放到fx隊(duì)列中,當(dāng)slideUp完成后,從隊(duì)列中被取出運(yùn)行。queue函數(shù)允許直接操作這個(gè)鏈?zhǔn)秸{(diào)用的行為。同時(shí),queue可以指定隊(duì)列名稱獲得其他能力,而不局限于fx隊(duì)列。
// 一般用法:
$("#foo").slideUp(function() {
alert("Animation complete.");
});
// 相當(dāng)于:
$("#foo").slideUp(); // 不提供回調(diào),只是觸發(fā)事件
$("#foo").queue(function() { // 把回調(diào)函數(shù)加入
alert("Animation complete.");
$(this).dequeue(); // 必須從隊(duì)列中取出,那么隊(duì)列中的下一個(gè)函數(shù)就有機(jī)會(huì)被調(diào)用
});
queue內(nèi)部使用data或者JavaScript數(shù)組API來(lái)保存數(shù)據(jù)。其中操作數(shù)組的push和shift天生就是一組隊(duì)列API。而data可以用來(lái)保存任意數(shù)據(jù)。
queue: function(elem, type, data) {
if(elem) {
// 默認(rèn)是fn
type = (type || "fx") + "queue";
// data內(nèi)部API:data(element, key, value, pvt);
// 這里不傳入data,是為了效率的考慮。如果沒(méi)傳入data,則只是get隊(duì)列,那么就不需要以下的判斷了
var q = jQuery.data(elem, type, undefined, true);
if(data) {
if(!q || jQuery.isArray(data)) {
q = jQuery.data(elem, type, jQuery.makeArray(data), true);
} else {
q.push(data); // 壓入
}
}
return q || [];
}
}
dequeue: function(elem, type) { type = type || "fx"; // 得到這個(gè)隊(duì)列 var queue = jQuery.queue(elem, type), // 出列一個(gè)元素 fn = queue.shift(), defer;
// "inprogress"崗哨
if(fn === "inprogress") {
fn = queue.shift();
}
if(fn) {
// 加一個(gè)崗哨,防止自動(dòng)出列
if(type === "fx") {
queue.unshift("inprogress");
}
// 執(zhí)行
fn.call(elem, function() {
jQuery.dequeue(elem, type);
});
}
if(!queue.length) {
jQuery.removeData(elem, type + "queue", true);
handleQueueMarkDefer(elem, type, "queue");
}
}
復(fù)制代碼 代碼如下:
// 一般用法:
$("#foo").slideUp(function() {
alert("Animation complete.");
});
// 相當(dāng)于:
$("#foo").slideUp(); // 不提供回調(diào),只是觸發(fā)事件
$("#foo").queue(function() { // 把回調(diào)函數(shù)加入
alert("Animation complete.");
$(this).dequeue(); // 必須從隊(duì)列中取出,那么隊(duì)列中的下一個(gè)函數(shù)就有機(jī)會(huì)被調(diào)用
});
queue內(nèi)部使用data或者JavaScript數(shù)組API來(lái)保存數(shù)據(jù)。其中操作數(shù)組的push和shift天生就是一組隊(duì)列API。而data可以用來(lái)保存任意數(shù)據(jù)。
復(fù)制代碼 代碼如下:
queue: function(elem, type, data) {
if(elem) {
// 默認(rèn)是fn
type = (type || "fx") + "queue";
// data內(nèi)部API:data(element, key, value, pvt);
// 這里不傳入data,是為了效率的考慮。如果沒(méi)傳入data,則只是get隊(duì)列,那么就不需要以下的判斷了
var q = jQuery.data(elem, type, undefined, true);
if(data) {
if(!q || jQuery.isArray(data)) {
q = jQuery.data(elem, type, jQuery.makeArray(data), true);
} else {
q.push(data); // 壓入
}
}
return q || [];
}
}
dequeue: function(elem, type) { type = type || "fx"; // 得到這個(gè)隊(duì)列 var queue = jQuery.queue(elem, type), // 出列一個(gè)元素 fn = queue.shift(), defer;
// "inprogress"崗哨
if(fn === "inprogress") {
fn = queue.shift();
}
if(fn) {
// 加一個(gè)崗哨,防止自動(dòng)出列
if(type === "fx") {
queue.unshift("inprogress");
}
// 執(zhí)行
fn.call(elem, function() {
jQuery.dequeue(elem, type);
});
}
if(!queue.length) {
jQuery.removeData(elem, type + "queue", true);
handleQueueMarkDefer(elem, type, "queue");
}
}
相關(guān)文章
jQuery實(shí)現(xiàn)的登錄浮動(dòng)框效果代碼
這篇文章主要介紹了jQuery實(shí)現(xiàn)的登錄浮動(dòng)框效果代碼,點(diǎn)擊登陸鏈接可彈出懸浮登錄框,涉及jQuery中show與hide方法的使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-09
使用jQuery仿蘋(píng)果官網(wǎng)焦點(diǎn)圖特效
這篇文章主要介紹了使用jQuery仿蘋(píng)果官網(wǎng)焦點(diǎn)圖特效,非常的炫酷,需要的朋友可以參考下2014-12-12
jQuery zTree如何改變指定節(jié)點(diǎn)文本樣式
這篇文章主要介紹了jQuery zTree如何改變指定節(jié)點(diǎn)文本樣式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-10-10
JQuery解析XML數(shù)據(jù)的幾個(gè)簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇JQuery解析XML數(shù)據(jù)的幾個(gè)簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-05-05
基于jQuery倒計(jì)時(shí)插件實(shí)現(xiàn)團(tuán)購(gòu)秒殺效果
倒計(jì)時(shí)在WEB上應(yīng)用非常廣泛,如考試系統(tǒng)倒計(jì)時(shí),團(tuán)購(gòu)網(wǎng)站中的優(yōu)惠活動(dòng)倒計(jì)時(shí)等等。今天,我們來(lái)使用jQuery倒計(jì)時(shí)超級(jí)實(shí)現(xiàn)團(tuán)購(gòu)秒殺效果,感興趣的朋友一起學(xué)習(xí)吧2016-05-05
juqery 學(xué)習(xí)之三 選擇器 層級(jí) 基本
juqery 學(xué)習(xí)之三 選擇器 層級(jí) 基本,學(xué)習(xí)jquery的朋友可以參考下。2010-11-11

