溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript如何異步調用框架

發(fā)布時間:2022-05-07 14:30:05 來源:億速云 閱讀:123 作者:iii 欄目:大數(shù)據(jù)

這篇文章主要講解了“JavaScript如何異步調用框架”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“JavaScript如何異步調用框架”吧!

調用入口

鏈式調用存在Async.go方法和Async.chain方法兩個入口,這兩個入口本質上是一致的,只是Async.chain方法在調用時先不提供初始參數(shù),而Async.go方法在調用時提供了初始參數(shù)并啟動異步調用鏈。

Async.chain = function() {    var chain = new Async.Operation({ chain: true });    return chain;  };   Async.go = function(initialArgument) {    return Async.chain().go(initialArgument);  }

在這里我們可以看到,鏈式調用本身也是一個Async.Operation,鏈式調用所需的go方法和next方法都是在Async.Operation上面做的擴展,并且這個擴展不會很難,這將在下一小節(jié)說明。

擴展方法

我們都知道,通過addCallback方法添加的回調函數(shù)是會被逐一執(zhí)行的,至少同步函數(shù)如此,因此我們可以用Async.Operation的這一特性來維護異步調用隊列,前提是我們?yōu)樗由蠈Ξ惒秸{用進行隊列的支持。

對于異步調用進行隊列的支持,我們稍后再來處理,首先我們利用現(xiàn)成的addCallback方法和yield方法擴展出go方法和next方法。

this.go = function(initialArgument) {    return this.yield(initialArgument);  }   this.next = function(nextFunction) {    return this.addCallback(nextFunction);  };

實際上,go方法和next方法直接調用的正是yield方法和addCallback方法。go方法的語義與yield方法一樣,傳遞一個參數(shù)給Async.Operation實例,并且啟動調用隊列。同時,next方法的語義和addCallback方法,添加一個調用到隊列的末端。

異步隊列

如何才能讓原本僅支持同步的隊列變得也支持異步?這需要檢測隊列中的每一個調用的返回,如果返回類型為Async.Operation,我們知道是JavaScript異步調用,從而使用特殊的方法等它執(zhí)行完后再執(zhí)行下去。

callbackResult = callback(self.result);  self.result = callbackResult;  if (callbackResult && callbackResult instanceof Async.Operation) {    innerChain = Async.chain();    while (callbackQueue.length > 0) {      innerChain.next(callbackQueue.shift());    }    innerChain.next(function(result) {      self.result = result;      self.state = "completed";      self.completed = true;      return result;    });    callbackResult.addCallback(function(result) {      self.result = result;      innerChain.go(result);    });  }

如果調用返回了一個Async.Operation實例,我們就利用它自身的addCallback方法幫我們執(zhí)行隊列中余下的調用。準確來說,是我們構造了一個新的調用鏈,把隊列余下的調用都轉移到新的調用鏈上,然后讓當前異步調用在回調中啟動這個新的調用鏈。

此外還有一些地方我們需要略作修改,以兼容新的異步調用隊列的。例如result、state、completed的狀態(tài)變更,在鏈式調用中是有所不同的。

感謝各位的閱讀,以上就是“JavaScript如何異步調用框架”的內容了,經(jīng)過本文的學習后,相信大家對JavaScript如何異步調用框架這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI