天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

JavaScript 異步方法隊(duì)列鏈實(shí)現(xiàn)代碼分析

在《Javascript設(shè)計(jì)模式》中對這種方法作了比較詳細(xì)的描述,實(shí)現(xiàn)方法的鏈?zhǔn)秸{(diào)用,只須讓在原型中定義的方法都返回調(diào)用這些方法的實(shí)例對象的引用即可,看看書中的這段代碼:
復(fù)制代碼 代碼如下:
(function() {
function _$(els) {
this.elements = [];
for (var i = 0, len = els.length; i < len; ++i) {
var element = els[i];
if (typeof element == 'string') {
element = document.getElementById(element);
}
this.elements.push(element);
}
};
_$.prototype = {
each: function(fn) {
for ( var i = 0, len = this.elements.length; i < len; ++i ) {
fn.call(this, this.elements[i]);
}
return this;
},
setStyle: function(prop, val) {
this.each(function(el) {
el.style[prop] = val;
});
return this;
},
show: function() {
var that = this;
this.each(function(el) {
that.setStyle('display', 'block');
});
return this;
},
addEvent: function(type, fn) {
var add = function(el) {
if (window.addEventListener) {
el.addEventListener(type, fn, false);
}
else if (window.attachEvent) {
el.attachEvent('on'+type, fn);
}
};
this.each(function(el) {
add(el);
});
return this;
}
};
window.$ = function() {
return new _$(arguments);
};
})();

可以看到,每個(gè)方法都以”return this”結(jié)束,這就會將調(diào)用方法的對象傳遞給鏈上的下一個(gè)方法。但是,如果我們要操作的數(shù)據(jù)是通過異步請求來獲得的,如何保持方法的鏈?zhǔn)秸{(diào)用呢?Dustin Diaz為我們提供了一種方法來保證方法的鏈?zhǔn)秸{(diào)用,他也是《Javascript設(shè)計(jì)模式》一書的作者之一。
他首先構(gòu)建了一個(gè)Queue對象,即:
復(fù)制代碼 代碼如下:
function Queue() {
// store your callbacks
this._methods = [];
// keep a reference to your response
this._response = null;
// all queues start off unflushed
this._flushed = false;
}
Queue.prototype = {
// adds callbacks to your queue
add: function(fn) {
// if the queue had been flushed, return immediately
if (this._flushed) {
fn(this._response);
// otherwise push it on the queue
} else {
this._methods.push(fn);
}
},
flush: function(resp) {
// note: flush only ever happens once
if (this._flushed) {
return;
}
// store your response for subsequent calls after flush()
this._response = resp;
// mark that it's been flushed
this._flushed = true;
// shift 'em out and call 'em back
while (this._methods[0]) {
this._methods.shift()(resp);
}
}
};

然后用它作為工具構(gòu)建我們的異步方法隊(duì)列鏈。有了這個(gè)工具,就可以很方便的構(gòu)建一個(gè)從服務(wù)器端獲取內(nèi)容并將其附加到選擇器中的jQuery plugin。
復(fù)制代碼 代碼如下:
(function($) {
$.fn.fetch = function(url) {
var queue = new Queue;
this.each(function() {
var el = this;
queue.add(function(resp) {
$(el).html(resp);
});
});
$.ajax({
url: url,
dataType: 'html',
success: function(html) {
queue.flush(html);
}
});
return this;
};
})(jQuery);

這樣,我們就可以異步的獲取內(nèi)容,并繼續(xù)我們的鏈?zhǔn)秸{(diào)用。
復(fù)制代碼 代碼如下:
$("<div/>")
.fetch('/server/navigation.html')
.addClass('column')
.appendTo('#side');

查看demo頁看看效果。
如果一個(gè)隊(duì)列中有很多項(xiàng)等待對服務(wù)器端的響應(yīng)進(jìn)行操作,該如何處置?作者構(gòu)建了這樣一個(gè)方法,值得參考:
復(fù)制代碼 代碼如下:
function fetchTweet(url) {
this.queue = new Queue;
this.tweet = "";
var self = this;
ajax(url, function(resp) {
self.tweet = resp;
self.queue.flush(this);
});
}
fetchTweet.prototype = {
linkify: function() {
this.queue.add(function(self) {
self.tweet = self.tweet.replace(//b@(/w{1,20}/b/g, '$1');
});
return this;
},
filterBadWords: function() {
this.queue.add(function(self) {
self.tweet = self.tweet.replace(//b(fuck|shit|piss)/b/g, "");
});
return this;
},
appendTo: function(selector) {
this.queue.add(function(self) {
$(self.tweet).appendTo(selector);
});
return this;
}
};

這樣,我們就可以用下面的方式來調(diào)用:
復(fù)制代碼 代碼如下:
fetchTweet(url).linkify().filterBadWords().appendTo('#status');

到此,我們已經(jīng)知道了如何實(shí)現(xiàn)異步方法鏈?zhǔn)秸{(diào)用,但在《Asynchronous method queue chaining in JavaScript》底部的一些評論提出的一些問題,值得思考一下。插件$.fn.fetch中僅僅只需將返回的內(nèi)容附加到元素之中,Queue是否必要?而且,jQuery中的$.fn.load完全可以實(shí)現(xiàn),如果Queue中只用一個(gè)回調(diào)函數(shù),完全可以這樣來寫:復(fù)制代碼 代碼如下:
(function($) {
$.fn.fetch = function(url) {
var queue = new Queue;
this.each(function() {
var el = this;
$.ajax({
url: url,
type: 'get',
dataType: 'json',
success: function(resp) {
$(el).html(resp['text1']);
}
});
});
return this;
};
})(jQuery);

不知你作如何感想?

JavaScript技術(shù)JavaScript 異步方法隊(duì)列鏈實(shí)現(xiàn)代碼分析,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美无码专区 | 2020美女视频黄频大全视频 | 中文日韩亚洲欧美字幕 | 日本超A大片在线观看 | 亚洲AV无码专区国产精品99 | 美女露出撒尿的部位 | 亚洲 自拍 偷拍 另类综合图区 | 亚洲欧美中文字幕先锋 | 久久日韩精品无码一区 | 成熟YIN荡美妞A片视频麻豆 | 久久精品天天爽夜夜爽 | 国产一区在线观看免费 | 九九热在线观看视频 | 免费光看午夜请高视频 | 手机在线播放成人亚洲影院电影 | 久久热在线视频精品店 | 免费在线观看的毛片 | 国产精品成人在线播放 | 女攻男受高h全文肉肉 | 亚洲第一区欧美日韩精品 | 日本高清免费观看 | 国产中文字幕在线 | 美美哒高清在线播放8 | www.欧美与曽交性video | 亚洲欧美日韩精品久久奇米色影视 | 国产一在线精品一区在线观看 | 波多野结衣教师系列6 | 日韩亚洲欧美中文高清 | 玩弄人妻少妇500系列网址 | 人妻少妇久久久久久97人妻 | 中文字幕一区中文亚洲 | 神马影院在线eecss伦理片 | 久久麻豆亚洲AV成人无码国产 | 试看2分钟AA片 | 亚洲国产精品热久久 | 成人在线免费看片 | 蝴蝶中文娱乐 | 免费看欧美一级特黄a大片 免费看欧美xxx片 | 中文字幕在线观看网站 | 亚洲精品久久国产高清 | 久久国产一区二区三区 |