亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

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

2019-11-20 20:42:55
字體:
來源:轉載
供稿:網友

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

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

下面我們將以 jQuery 為例討論 JavaScript 庫是如何使用 Promise 模式的來處理異步的,其實就是通過回調的方式提供容錯支持。在某個操作成功或失敗或任何情況下都執行對應的回調,盡量把某段邏輯可能出現的情況都 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 調用完成后,它便會執行 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 方法,這樣做的優勢是你可以鏈式調用,實現獨立操作,如下所示 :

復制代碼 代碼如下:

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 來操作異步是一種非常簡單的方式,而且還可以簡化你的代碼,確實是一舉兩得的好方法。
更多關于Promise的介紹及示例,可以前往官網(http://www.promisejs.org/)查看。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色综合导航网站| 欧美性xxxx极品高清hd直播| 91亚洲午夜在线| 精品视频9999| 国产综合久久久久| 精品人伦一区二区三区蜜桃免费| 日韩美女毛茸茸| 欧美在线视频一区| 视频在线观看99| 国产一区二区三区在线观看视频| 久久久亚洲网站| 国产亚洲精品美女久久久久| 日韩不卡中文字幕| 538国产精品一区二区免费视频| 亚洲欧洲午夜一线一品| 在线不卡国产精品| 日韩小视频在线| 色99之美女主播在线视频| 国产成人自拍视频在线观看| 国产成人黄色av| 亚洲精品欧美极品| 久久精品视频免费播放| 1769国内精品视频在线播放| 欧美亚洲一级片| 福利二区91精品bt7086| 日韩风俗一区 二区| 成人有码在线视频| 亚洲精品不卡在线| 97精品伊人久久久大香线蕉| 色噜噜狠狠色综合网图区| 亚洲乱码一区av黑人高潮| 欧美日韩国产中文精品字幕自在自线| 久久精品91久久久久久再现| 久久久www成人免费精品| 亚洲国产精品久久久| 久久精品视频在线播放| 久久久久久中文| 欧美激情图片区| 精品成人乱色一区二区| 国产精品私拍pans大尺度在线| 97在线观看免费| 欧美日韩国产精品一区二区三区四区| 欧美性xxxxx极品| 日韩精品欧美激情| 97欧美精品一区二区三区| 日韩美女视频中文字幕| 日韩国产高清视频在线| 亚洲天堂网站在线观看视频| 日韩在线视频网| 国产精品美女久久久久av超清| 日本亚洲欧美成人| 国产精品成人v| 91色视频在线观看| 亚洲精品福利在线| 狠狠久久亚洲欧美专区| 亚洲综合中文字幕在线观看| 久久精品久久久久电影| 亚洲日韩中文字幕在线播放| 国产精品自产拍在线观看| 国内偷自视频区视频综合| 国产综合视频在线观看| 久久噜噜噜精品国产亚洲综合| 国产精品第一区| 欧美特黄级在线| 国产日韩视频在线观看| 国产精品久久久久久久久久久久久| 亚洲a在线播放| 国产日韩欧美视频在线| 91国产一区在线| 九九热最新视频//这里只有精品| 欧美性在线视频| 欧美国产日韩中文字幕在线| 久久777国产线看观看精品| 久久久久久美女| 亚洲天堂第一页| 亚洲色图色老头| 亚洲影院色无极综合| 亚洲激情视频在线播放| 日韩av电影国产| 国产精品精品国产| 国产91ⅴ在线精品免费观看| 国内精品久久影院| 精品福利在线观看| 欧美黑人国产人伦爽爽爽| 欧美成人一区二区三区电影| 欧洲成人在线视频| 91成人福利在线| 日韩av中文字幕在线| 岛国视频午夜一区免费在线观看| 91黑丝高跟在线| 成人免费观看49www在线观看| 欧美日韩国产一区在线| 另类少妇人与禽zozz0性伦| 激情懂色av一区av二区av| 日韩中文字幕在线观看| 午夜精品久久久久久久久久久久| 久久免费国产视频| 91久久综合亚洲鲁鲁五月天| 欧美国产日韩视频| 亚洲第一视频在线观看| 久久精品在线播放| 欧美成人精品一区| 国产精品99久久久久久久久| 91在线免费网站| 亚洲国产精品女人久久久| 亚洲第一国产精品| 国内精品久久久久久| 最近2019中文字幕第三页视频| 欧美国产日韩二区| 亚洲午夜色婷婷在线| 国产精品久久久久久久午夜| 欧美成aaa人片在线观看蜜臀| 欧美理论在线观看| 亚洲国产女人aaa毛片在线| 欧美黄色片免费观看| 欧美日韩一区二区三区| 亚洲成人久久久| 欧美精品videosex性欧美| 乱亲女秽乱长久久久| 欧美黑人狂野猛交老妇| 亚洲人av在线影院| 国产第一区电影| 欧美在线观看一区二区三区| 色先锋资源久久综合5566| 欧美高清在线观看| 亚洲人成电影网站色…| 日韩av电影手机在线观看| 欧美最猛性xxxxx(亚洲精品)| 日本高清久久天堂| 欧美成人黑人xx视频免费观看| www.日韩免费| 欧美日韩国产第一页| 欧美精品激情在线观看| 久久在线精品视频| 日韩电影大片中文字幕| 欧美大片大片在线播放| 91精品综合久久久久久五月天| 国产精品国产三级国产aⅴ浪潮| 国产69久久精品成人看| 91在线精品视频| 欧美成人免费全部观看天天性色| 日韩女优在线播放| 91在线观看免费网站| 日韩av片电影专区| 久久99国产精品久久久久久久久| 色偷偷偷亚洲综合网另类| 国产性猛交xxxx免费看久久| 国产91亚洲精品| 午夜精品一区二区三区在线视频| 懂色aⅴ精品一区二区三区蜜月| 国产一区欧美二区三区| 精品亚洲永久免费精品| 久久久精品在线观看| 51视频国产精品一区二区| 久久人人爽人人爽爽久久| 国产精品男人的天堂| 91免费欧美精品| 欧美做爰性生交视频| 日韩电影在线观看免费| 2019国产精品自在线拍国产不卡| 成人夜晚看av| 狠狠躁夜夜躁人人爽超碰91| 爽爽爽爽爽爽爽成人免费观看| 欧美视频免费在线|