Javascript異步編程模型Promise模式詳細介紹
來源:易賢網 閱讀:4096 次 日期:2014-05-09 15:03:28
溫馨提示:易賢網小編為您整理了“Javascript異步編程模型Promise模式詳細介紹”,方便廣大網友查閱!

異步模式在 Web 編程中變得越來越重要,如何處理異步請求后的操作是一件麻煩事。Promise 是一種異步編程模型,術語稱作 Deferred 模式,它通過一組API來規(guī)范化異步操作,讓異步操作的流程控制更加容易。

Promise 編程模式也被稱為 thenable,可以理解為 延遲后執(zhí)行。每個 Promise 都擁有一個叫做 then 的唯一接口,當 Promise 失敗或成功時,它就會進行回調。它代表了一種可能會長時間運行而且不一定必須完成的操作結果。這種模式不會阻塞和等待長時間的操作完成,而是返回一個代表了承諾的(promised)結果的對象。

當前的許多 JavaScript 庫(如 jQuery 和 Dojo、AngularJS)均添加了這種稱為 Promise 的抽象。通過這些庫,開發(fā)人員能夠在實際編程中使用 Promise 模式。

下面我們將以 jQuery 為例討論 JavaScript 庫是如何使用 Promise 模式的來處理異步的,其實就是通過回調的方式提供容錯支持。在某個操作成功或失敗或任何情況下都執(zhí)行對應的回調,盡量把某段邏輯可能出現的情況都 handle 住。

首先讓我們來看看 jQuery 一般是如何操作的:

代碼如下:

var $info = $("#info");

$.ajax({

url:"/echo/json/",

data: { json: JSON.stringify({"name": "someValue"}) },

type:"POST",

success: function(response)

{

$info.text(response.name);

}

});

在這個例子中,你可以看到當設置成功后會指定一個回調,是一種很好的回調方式,這并不是 Promise,jQuery 官方文檔也不再推薦這種方式(http://api.jquery.com/jQuery.ajax/#jqXHR)。 當 Ajax 調用完成后,它便會執(zhí)行 success 函數。根據庫所使用的異步操作,你可以使用各種不同的回調(即任務是否成功,都會進行回調,做出響應)。使用 Promise 模式會簡化這個過程,異步操作只需返回一個對象調用。這個 Promise 允許你調用一個叫做 then 的方法,然后讓你指定回調的 function(s) 個數。

下面讓我們來看看 jQuery 是如何建立 Promise 的:

代碼如下:

var $info = $("#info");

$.ajax({

url: "/echo/json/",

data: {

json: JSON.stringify({

"name": "someValue"

})

},

type: "POST"

})

.then(function (response) {

$info.text(response.name);

});

jQuery ajax 對象通過返回 xhr 對象實現 Promise 模式,所以我們可以調用 then 方法,這樣做的優(yōu)勢是你可以鏈式調用,實現獨立操作,如下所示 :

復制代碼 代碼如下:

var $info = $("#info");

$.ajax({

url: "/echo/json/",

data: {

json: JSON.stringify({

"name": "someValue"

})

},

type: "POST"

})

.then(function (response) {

$info.text(response.name);

})

.then(function () {

$info.append("...More");

})

.done(function () {

$info.append("...finally!");

});

由于許多庫都開始采用 Promise 模式,所以異步操作會變的非常容易。但如果站在相反的角度思考,Promise 將會是什么樣子的呢?其中一個非常重要的模式是函數可以接受兩種功能,一個是成功時的回調,另一個是失敗時的回調。

代碼如下:

var $info = $("#info");

$.ajax({

// Change URL to see error happen

url: "/echo/json/",

data: {

json: JSON.stringify({

"name": "someValue"

})

},

type: "POST"

})

.then(function (response) {

// success

$info.text(response.name);

},

function () {

// failure

$info.text("bad things happen to good developers");

})

.always(function () {

$info.append("...finally");

});

需要注意的是,在 jQuery 里,無論成功還是失敗,我們都會使用一個調用來指定我們想要調用的。

其實這里也可以這樣來寫,這也是 jQuery 官方文檔里推薦的方法:

代碼如下:

var $info = $("#info");

$.ajax({

// Change URL to see error happen

url: "/echo/json/",

data: {

json: JSON.stringify({

"name": "someValue"

})

},

type: "POST"

})

.done(function (response) {

// success

$info.text(response.name);

}).fail(function () {

// failure

$info.text("bad things happen to good developers");

})

.always(function () {

$info.append("...finally");

});

下面再來看看 AngularJS 是如何使用 Promise 模式的:

代碼如下:

var m = angular.module("myApp", []);

m.factory("dataService", function ($q) {

function _callMe() {

var d = $q.defer();

setTimeout(function () {

d.resolve();

//defer.reject();

}, 100);

return d.promise;

}

return {

callMe: _callMe

};

});

function myCtrl($scope, dataService) {

$scope.name = "None";

$scope.isBusy = true;

dataService.callMe()

.then(function () {

// Successful

$scope.name = "success";

},

function () {

// failure

$scope.name = "failure";

})

.then(function () {

// Like a Finally Clause

$scope.isBusy = false;

});

}

你可以在 JSFiddle 里試試這些例子,并且看看會產生哪些效果。使用 Promise 來操作異步是一種非常簡單的方式,而且還可以簡化你的代碼,確實是一舉兩得的好方法。

更多信息請查看IT技術專欄

更多信息請查看網絡編程

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網