欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript 異步調(diào)用框架 (Part 6 - 實(shí)例 & 模式)

 更新時(shí)間:2009年08月04日 00:15:42   作者:  
我們用了5篇文章來(lái)討論如何編寫(xiě)一個(gè)JavaScript異步調(diào)用框架(問(wèn)題 & 場(chǎng)景、用例設(shè)計(jì)、代碼實(shí)現(xiàn)、鏈?zhǔn)秸{(diào)用、鏈?zhǔn)綄?shí)現(xiàn)),現(xiàn)在是時(shí)候讓我們看一下在各種常見(jiàn)開(kāi)發(fā)情景中如何使用它了。
封裝Ajax
設(shè)計(jì)Async.Operation的最初目的就是解決Ajax調(diào)用需要傳遞callback參數(shù)的問(wèn)題,為此我們先把Ajax請(qǐng)求封裝為Async.Operation。我在這里使用的是jQuery,當(dāng)然無(wú)論你用什么基礎(chǔ)庫(kù),在使用Async.Operation時(shí)都可以做這種簡(jiǎn)單的封裝。
復(fù)制代碼 代碼如下:

var Ajax = {};

Ajax.get = function(url, data) {
var operation = new Async.Operation();
$.get(url, data, function(result) { operation.yield(result); }, "json");
return operation;
};

Ajax.post = function(url, data) {
var operation = new Async.Operation();
$.post(url, data, function(result) { operation.yield(result); }, "json");
return operation;
};

在我所調(diào)用的服務(wù)器端API中,只需要GET和POST,且數(shù)據(jù)都為JSON,所以我就直接把jQuery提供的其它Ajax選項(xiàng)屏蔽掉了,并設(shè)置數(shù)據(jù)類(lèi)型為JSON。在你的項(xiàng)目當(dāng)中,也可以用類(lèi)似的方式將Ajax封裝為若干僅僅返回Async.Operation的方法,將jQuery提供的選項(xiàng)都封裝在Ajax這一層內(nèi),不再向上層暴露這些選項(xiàng)。

調(diào)用Ajax
把Ajax封裝好后,我們就可以開(kāi)始專(zhuān)心寫(xiě)業(yè)務(wù)邏輯了。

假設(shè)我們有一個(gè)Friend對(duì)象,它的get方法用于返回單個(gè)好友對(duì)象,而getAll方法用于返回所有好友對(duì)象。于此對(duì)應(yīng)的是兩個(gè)服務(wù)器端API,friend接口會(huì)返回單個(gè)好友JSON,而friendlist接口會(huì)返回所有好友名稱(chēng)組成的JSON。

首先我們看看較為基礎(chǔ)的get方法怎么寫(xiě):
復(fù)制代碼 代碼如下:

function get(name) {
return Ajax.get("/friend", "name=" + encodeURIComponent(name));
}

就這么簡(jiǎn)單?對(duì)的,假如服務(wù)器端API返回的JSON結(jié)構(gòu)正好就是你要的好友對(duì)象結(jié)構(gòu)的話(huà)。如果JSON結(jié)構(gòu)和好友對(duì)象結(jié)構(gòu)是異構(gòu)的,或許你還要加點(diǎn)代碼來(lái)把JSON映射為對(duì)象:
復(fù)制代碼 代碼如下:

function get(name) {
var operation = new Async.Operation()
Ajax.get("/friend", "name=" + encodeURIComponent(name))
.addCallback(function(json) {
operation.yield(createFriendFromJson(json));
});
return operation;
}

Ajax隊(duì)列
接下來(lái)我們要編寫(xiě)的是getAll方法。因?yàn)閒riendlist接口只返回好友名稱(chēng)列表,因此在取得這份列表后我們還要逐一調(diào)用get方法獲取具體的好友對(duì)象??紤]到在同時(shí)進(jìn)行多個(gè)friend接口調(diào)用可能觸發(fā)服務(wù)器的防攻擊策略,導(dǎo)致被關(guān)小黑屋一段時(shí)間,所以對(duì)friend接口的調(diào)用必須排隊(duì)。
復(fù)制代碼 代碼如下:

function getAll(){
var operation = new Async.Operation();
var friends = [];
var chain = Async.chain();
Ajax.get("/friendlist", "")
.addCallback(function(json) {
for (var i = 0; i < json.length; i++) {
chain.next(function() {
return get(json.shift())
.addCallback(function(friend) { friends.push(friend); });
});
}
chain
.next(function() { operation.yield(friends); })
.go();
})
return operation;
}

在這里,我們假設(shè)friendlist接口返回的JSON就是一個(gè)Array,在獲取到這個(gè)Array后構(gòu)造一個(gè)等長(zhǎng)的異步調(diào)用隊(duì)列,其中每一個(gè)調(diào)用的邏輯都是一樣的——取出Array中首個(gè)好友的名稱(chēng),用get方法獲取對(duì)應(yīng)的好友對(duì)象,再將好友對(duì)象放入另一個(gè)Array中。在調(diào)用隊(duì)列的末端,我們?cè)僮芳恿艘粋€(gè)調(diào)用,用于返回保存好友對(duì)象的Array。

在這個(gè)例子當(dāng)中,我們沒(méi)有利用調(diào)用隊(duì)列會(huì)把上一個(gè)函數(shù)的結(jié)果傳遞給下一個(gè)函數(shù)的特性,不過(guò)也足夠展示調(diào)用隊(duì)列的用途了——讓多個(gè)底層為Ajax請(qǐng)求的異步操作按照固定的順序阻塞式執(zhí)行。

由于底層異步函數(shù)返回的就是Async.Operation,你可以直接把它傳遞給next方法,也可以用匿名函數(shù)包裝后傳遞給next方法,而匿名函數(shù)內(nèi)部只需要一個(gè)return。

延時(shí)函數(shù)
在上面的例子中,使用隊(duì)列是為了避免觸發(fā)服務(wù)器的防攻擊策略,但有時(shí)候這還是不夠的。例如說(shuō),服務(wù)器要求兩個(gè)請(qǐng)求之間至少間隔500毫秒,否則就認(rèn)為是攻擊,那么我們就要在隊(duì)列里面插入這個(gè)間隔了。

在原本next方法調(diào)用的匿名函數(shù)中手動(dòng)加入setTimeout是一個(gè)辦法,但為什么我們不寫(xiě)一個(gè)輔助函數(shù)來(lái)解決這類(lèi)問(wèn)題呢?讓我們來(lái)寫(xiě)一個(gè)輔助方法并讓它和Async.Operation無(wú)縫結(jié)合起來(lái)。
復(fù)制代碼 代碼如下:

Async.wait = function(delay, context) {
var operation = new Async.Operation();
setTimeout(function() { operation.yield(context); }, delay);
return operation;
};

Async.Operation.prototype.wait = function(delay, context) {
this.next(function(context) { return Async.wait(delay, context); });
}

在有了這個(gè)輔助方法后,我們就可以在上述getAll方法中輕松實(shí)現(xiàn)在每個(gè)Ajax請(qǐng)求之間間隔500毫秒。在for循環(huán)內(nèi)的加上對(duì)wait的調(diào)用就可以了。
復(fù)制代碼 代碼如下:

for (var i = 0; i < json.length; i++) {
chain
.wait(500)
.next(function() {
return get(json.shift())
.addCallback(function(friend) { friends.push(friend); });
});
}

小結(jié)
通過(guò)一些簡(jiǎn)單的例子,我們了解到了Async.Operation常見(jiàn)的使用方式,以及在有需要的時(shí)候如何擴(kuò)展它的功能。希望Async.Operation能夠有效幫助大家提高Ajax應(yīng)用的代碼可讀性。

相關(guān)文章

  • TypeScript 類(lèi)型編程之索引類(lèi)型遞歸去掉可選修飾

    TypeScript 類(lèi)型編程之索引類(lèi)型遞歸去掉可選修飾

    這篇文章主要介紹了TypeScript 類(lèi)型編程之索引類(lèi)型遞歸去掉可選修飾,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • Bootstrap按鈕功能之查詢(xún)按鈕和重置按鈕

    Bootstrap按鈕功能之查詢(xún)按鈕和重置按鈕

    一般情況下,查詢(xún)列表有查詢(xún)條件、查詢(xún)按鈕和重置按鈕,輸入查詢(xún)條件,點(diǎn)擊查詢(xún)按鈕查詢(xún)列表等數(shù)據(jù);點(diǎn)擊重置按鈕會(huì)將查詢(xún)條件恢復(fù)到原始狀態(tài)。接下來(lái)通過(guò)本文給大家介紹bootstrap實(shí)現(xiàn)查詢(xún)按鈕和重置按鈕的方法,一起看看吧
    2016-10-10
  • 你不知道的高性能JAVASCRIPT

    你不知道的高性能JAVASCRIPT

    想必大家都知道,JavaScrip是全棧開(kāi)發(fā)語(yǔ)言,瀏覽器,手機(jī),服務(wù)器端都可以看到JS的身影。 本文會(huì)分享一些高效的JavaScript的最佳實(shí)踐,提高大家對(duì)JS的底層和實(shí)現(xiàn)原理的理解,感興趣的小伙伴們可以參考一下
    2016-01-01
  • BOM操作querySelector?querySeletorAll獲取標(biāo)簽對(duì)象

    BOM操作querySelector?querySeletorAll獲取標(biāo)簽對(duì)象

    這篇文章主要為大家介紹了BOM操作querySelector?querySeletorAll獲取標(biāo)簽對(duì)象步驟詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • Array.prototype 的泛型應(yīng)用分析

    Array.prototype 的泛型應(yīng)用分析

    Array.prototype 的泛型應(yīng)用分析,需要的朋友可以參考下。
    2010-04-04
  • JS實(shí)現(xiàn)關(guān)閉小廣告特效

    JS實(shí)現(xiàn)關(guān)閉小廣告特效

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)關(guān)閉小廣告特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • 原生JS實(shí)現(xiàn)幻燈片

    原生JS實(shí)現(xiàn)幻燈片

    本文主要介紹了原生JS實(shí)現(xiàn)幻燈片的示例代碼,具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-02-02
  • JS 對(duì)輸入框進(jìn)行限制(常用的都有)

    JS 對(duì)輸入框進(jìn)行限制(常用的都有)

    本文為大家介紹下使用js對(duì)輸入框進(jìn)行限制:文本框只能輸入數(shù)字代碼、只能輸入數(shù)字、只能輸入字母和漢字、只能輸入英文字母和數(shù)字等等,還有很多,感興趣的可以學(xué)習(xí)下
    2013-07-07
  • layui實(shí)現(xiàn)tab的添加拒絕重復(fù)的方法

    layui實(shí)現(xiàn)tab的添加拒絕重復(fù)的方法

    今天小編就為大家分享一篇layui實(shí)現(xiàn)tab的添加拒絕重復(fù)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-09-09
  • js寫(xiě)的評(píng)論分頁(yè)(還不錯(cuò))

    js寫(xiě)的評(píng)論分頁(yè)(還不錯(cuò))

    js寫(xiě)的分頁(yè)在網(wǎng)上可以搜到很多的文章,在也為大家介紹一個(gè),喜歡的的朋友可以參考下
    2013-12-12

最新評(píng)論