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

Javascript異步編程模型Promise模式詳細介紹

 更新時間:2014年05月08日 10:40:36   作者:  
異步模式在 Web 編程中變得越來越重要,如何處理異步請求后的操作是一件麻煩事。Promise 是一種異步編程模型,術(shù)語稱作 Deferred 模式,它通過一組API來規(guī)范化異步操作,讓異步操作的流程控制更加容易。

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

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

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

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

復(fù)制代碼 代碼如下:

var $info = $("#info");
$.ajax({
    url:"/echo/json/",
    data: { json: JSON.stringify({"name": "someValue"}) },
    type:"POST",
    success: function(response)
    {
       $info.text(response.name);
    }
});

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

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

復(fù)制代碼 代碼如下:

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 對象實現(xiàn) Promise 模式,所以我們可以調(diào)用 then 方法,這樣做的優(yōu)勢是你可以鏈式調(diào)用,實現(xiàn)獨立操作,如下所示 :

復(fù)制代碼 代碼如下:

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 將會是什么樣子的呢?其中一個非常重要的模式是函數(shù)可以接受兩種功能,一個是成功時的回調(diào),另一個是失敗時的回調(diào)。

復(fù)制代碼 代碼如下:

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 里,無論成功還是失敗,我們都會使用一個調(diào)用來指定我們想要調(diào)用的。
其實這里也可以這樣來寫,這也是 jQuery 官方文檔里推薦的方法:

復(fù)制代碼 代碼如下:

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 模式的:

復(fù)制代碼 代碼如下:

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 里試試這些例子,并且看看會產(chǎn)生哪些效果。使用 Promise 來操作異步是一種非常簡單的方式,而且還可以簡化你的代碼,確實是一舉兩得的好方法。
更多關(guān)于Promise的介紹及示例,可以前往官網(wǎng)(http://www.promisejs.org/)查看。

相關(guān)文章

  • 聊聊JS動畫庫 Velocity.js的使用

    聊聊JS動畫庫 Velocity.js的使用

    本篇文章主要介紹了聊聊JS動畫庫 Velocity.js的使用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • 淺談webpack 構(gòu)建性能優(yōu)化策略小結(jié)

    淺談webpack 構(gòu)建性能優(yōu)化策略小結(jié)

    webpack以其豐富的功能和靈活的配置而深受業(yè)內(nèi)吹捧,逐步取代了grunt和gulp成為大多數(shù)前端工程實踐中的首選,這篇文章主要介紹了淺談webpack 構(gòu)建性能優(yōu)化策略小結(jié),感興趣的小伙伴們可以參考一下
    2018-06-06
  • js下關(guān)于onmouseout、事件冒泡的問題經(jīng)驗小結(jié)

    js下關(guān)于onmouseout、事件冒泡的問題經(jīng)驗小結(jié)

    第3次遇到這個問題,于是總結(jié)了一下,將此短文發(fā)在首頁,希望對瀏覽器事件機制有所了解的大俠們給予解答
    2010-12-12
  • 原生js實現(xiàn)給指定元素的后面追加內(nèi)容

    原生js實現(xiàn)給指定元素的后面追加內(nèi)容

    給指定元素的后面追加一些自己想要實現(xiàn)的效果或者是一些屬性之類的,有木有遇到過,接下來為大家詳細介紹下追加的實現(xiàn)代碼,感興趣的朋友可以參考下哈
    2013-04-04
  • js獲取系統(tǒng)的根路徑實現(xiàn)介紹

    js獲取系統(tǒng)的根路徑實現(xiàn)介紹

    js如何獲取系統(tǒng)的根路徑,在本文給出了詳細的方法,感興趣的朋友可以參考下,希望對大家有所幫助
    2013-09-09
  • 再次談?wù)揓avascript中的this

    再次談?wù)揓avascript中的this

    javascript中的this應(yīng)用非常廣泛,對js中this總是似是而非的感覺,今天小編豁然開朗,然后再次給大家談?wù)搄s中的this關(guān)鍵,感興趣的朋友跟著小編一起看看吧
    2016-06-06
  • 開發(fā)跨瀏覽器javascript常見注意事項

    開發(fā)跨瀏覽器javascript常見注意事項

    對于javascript的開發(fā)人員來說,多瀏覽器的支持性,一直是個問題,每次都要經(jīng)過測試,多個瀏覽器,才能使用下面一些常見的一些注意事項。
    2009-01-01
  • 你不知道的Git?log還有這種用法

    你不知道的Git?log還有這種用法

    這篇文章主要為大家介紹了你不知道的Git?log竟然還有這種用法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • JavaScript獲取一個范圍內(nèi)日期的方法

    JavaScript獲取一個范圍內(nèi)日期的方法

    這篇文章主要介紹了JavaScript獲取一個范圍內(nèi)日期的方法,涉及javascript操作日期的相關(guān)技巧,需要的朋友可以參考下
    2015-04-04
  • JavaScript 實現(xiàn)類似Express的中間件系統(tǒng)(實例詳解)

    JavaScript 實現(xiàn)類似Express的中間件系統(tǒng)(實例詳解)

    在 Express 中可以給一個請求設(shè)置若干個中間件,在處理響應(yīng)時會按順序執(zhí)行這些中間件,正在執(zhí)行的中間件可以控制是否執(zhí)行下一個中間件,這篇文章主要介紹了JavaScript 實現(xiàn)類似Express的中間件系統(tǒng)的相關(guān)資料,需要的朋友可以參考下
    2023-02-02

最新評論