中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

JavaScript 異步調(diào)用框架 (Part 2 - 用例設(shè)計)

傳遞回調(diào)
我們首先要考慮的一個問題是,如何傳遞回調(diào)入口。在最傳統(tǒng)的XHR調(diào)用當中,回調(diào)函數(shù)會被作為最后一個參數(shù)傳遞給異步函數(shù):
復(fù)制代碼 代碼如下:
function asyncOperation(argument, callback)

在參數(shù)相當多的時候,我們可以把參數(shù)放到一個JSON里面,這樣參數(shù)就如同具名參數(shù)一樣,可以通過參數(shù)名選擇性的傳遞參數(shù),不傳遞的參數(shù)相當于使用默認值。這是從Prototype開始就流行起來的做法:
復(fù)制代碼 代碼如下:
function asyncOperation(argument, options)

然而這兩種做法都有一個壞處,就是把同步函數(shù)改為異步函數(shù)(或同步異步混合函數(shù))時,必須顯式地修改函數(shù)簽名,在最后增加一個(或多個)參數(shù)。

由于在調(diào)用棧的底層引入異步函數(shù)對我們來說太常見了,為此可能要更改一大堆上層調(diào)用函數(shù)簽名的成本實在是太高了,所以我們還是想一個不用修改函數(shù)簽名的做法吧。

在這里我參考了.NET Framework的IAsyncResult設(shè)計,把異步操作有關(guān)的一切信息集中到一個對象上來,從而避免了對函數(shù)簽名的修改。在此,我們假設(shè)一個異步函數(shù)的調(diào)用原型是這樣子的:
復(fù)制代碼 代碼如下:
function asyncOperation(argument) {
operation = new Async.Operation();
setTimeout(function() { operation.yield("hello world"); }, 1000);
return operation;
}

在這段代碼里,我們返回了一個Operation對象,用于將來傳遞回調(diào)函數(shù)。同時,我們通過setTimeout模擬了異步返回結(jié)果,而具體的返回方式就是yield方法。

接著,我們還要設(shè)計傳遞回調(diào)函數(shù)的方法。由于我們不能好像C#那樣重載+=運算符,所以只能用函數(shù)傳遞回調(diào)函數(shù):
復(fù)制代碼 代碼如下:
var operation = asyncOperation(argument);
operation.addCallback(function(result) { alert(result); });

在C#里面做這樣的設(shè)計是不安全的,因為在異步操作可能在添加回調(diào)之前就完成了。但在JavaScript里面這樣寫是安全的,因為JavaScript是單線程的,緊接著asyncOperation的同步addCallback必然先執(zhí)行,asyncOperation中的異步y(tǒng)ield必然后執(zhí)行。

調(diào)用順序
可能有人要問,如果用戶使用同步的方式來調(diào)用yield,這時候執(zhí)行順序不一樣依賴于yield的實現(xiàn)嗎?沒錯,不過yeild是在框架中一次性實現(xiàn)的,我們只要把它做成異步的就可以了,這樣即使對它進行同步調(diào)用,也不影響執(zhí)行順序:
復(fù)制代碼 代碼如下:
function psudoAsyncOperation(argument) {
operation = new Async.Operation();
operation.yield("hello world");
return operation;
}
var operation = asyncOperation(argument);
operation.addCallback(function(result) { alert(result); });

就算把代碼寫成這個樣子,我們也能確保addCallback先于yield的實際邏輯執(zhí)行。

事后回調(diào)
有時候,框架的使用者可能真的寫出了先yield后addCallback的代碼。這時候,我認為必須保證addCallback中添加的回調(diào)函數(shù)會被立即觸發(fā)。因為用戶添加這個回調(diào)函數(shù),意味著他期望當異步操作有結(jié)果時通知這個回調(diào)函數(shù),而這與添加回調(diào)函數(shù)時異步操作是否完成無關(guān)。為此,我們再添加一個用例:
復(fù)制代碼 代碼如下:
function psudoAsyncOperation(argument) {
operation = new Async.Operation();
operation.yield("hello world");
return operation;
}
var operation = asyncOperation(argument);
setTimeout(function() {
operation.addCallback(function(result) { alert(result); });
}, 1000);

小結(jié)
到這里,我們就設(shè)計好了一個名為Async.Operation的異步操作對象,具體如何實現(xiàn)關(guān)鍵的yield方法和addCallback方法將在下一篇文章講述如果。

JavaScript技術(shù)JavaScript 異步調(diào)用框架 (Part 2 - 用例設(shè)計),轉(zhuǎn)載需保留來源!

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

主站蜘蛛池模板: 久久久久久久一区 | 男女羞羞视频大全 | 国产精品国产三级国产aⅴ入口 | 在线免费看黄 | 国户精品久久久久久久久久久不卡 | 亚洲免费成人 | 欧美综合一区 | 国产一级片在线观看视频 | 羞羞的视频免费看 | 91精品国产91 | 久久国内精品 | 欧美久久一区二区三区 | 91精品一区二区三区久久久久 | 一区精品视频在线观看 | 色888www视频在线观看 | 国产精品亚洲综合 | 91新视频| 九九精品网 | 国产精品美女久久久免费 | 国产国产精品久久久久 | 国产精品一区二区欧美黑人喷潮水 | 91麻豆蜜桃一区二区三区 | 欧美日韩一 | 成人在线中文 | 天天干天天玩天天操 | 九九在线视频 | 天天视频一区二区三区 | 亚洲欧美一区二区三区在线 | 日韩一二区 | 国产精品精品久久久久久 | 性一交一乱一伦视频免费观看 | julia中文字幕久久一区二区 | 一区二区三区网站 | 日日骚视频 | 中文字幕精品一区二区三区精品 | www精品美女久久久tv | 91精品国产高清久久久久久久久 | 中文字幕在线第二页 | 国产wwwcom| 精品国产一区二区三区性色av | 黄色一级电影在线观看 |