中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

使用Promise模式來簡化javascript的異步回調

2023-10-26    分類: 網(wǎng)站建設

百度權重查詢 站長交易 友情鏈接交換 網(wǎng)站監(jiān)控 服務器監(jiān)控 seo監(jiān)控

網(wǎng)頁的交互越來越復雜,javascript 的異步操作也隨之越來越多。如常見的 ajax 請求,需要在請求完成時響應操作,請求通常是異步的,請求的過程中用戶還能進行其他的操作,不會對頁面進行壅塞,這種異步的交互效果對用戶來說是挺有友愛的。但是對于開發(fā)者來說,要大量處理這種操作,就很不友愛了。異步請求完成的操作必須預先定義在回調函數(shù)中,等到請求完成就必須調用這個函數(shù)。這種非線性的異步編程體例會讓開發(fā)者很不適應,同時也帶來了諸多的未便,增添了代碼的耦合度和復雜性,代碼的組織上也會很不優(yōu)雅,大大降低了代碼的可維護性。情況再復雜點,假如一個操作要等到多個異步 ajax 請求的完成才能進行,就會出現(xiàn)回調函數(shù)嵌套的情況,假如需要嵌套好幾層,那你就只能自求多福了。

先看看下面這個常見的異步函數(shù)。

var showMsg = function(){

setTimeout(function(){

alert( ‘hello’ );

}, 5000 );

};

假如要給該函數(shù)添加回調,通常會這么干。

var showMsg = function( callback ){

setTimeout(function(){

alert( ‘hello’ );

// 此處添加回調

callback();

}, 5000 );

};

假如是使用 easy.js 的 Promise,添加回調的方法就會優(yōu)雅多了,前提是需要將原函數(shù)封裝成一個 promise 實例。

var showMsg = function(){

// 構造promise實例

var promise = new E.Promise();

setTimeout(function(){

alert( ‘hello’ );

// 改變promise的狀況

promise.resolve( ‘done’ );

}, 5000 );

// 返回promise實例

return promise;

};

將一個通俗的函數(shù)封裝成一個 promise 實例,有3個關鍵步驟,步是在函數(shù)內部構造一個 promise 實例,第二步是部署函數(shù)執(zhí)行完去改變 promise 的狀況為已完成,第三步就是返回這個 promise 實例。每個 promise 實例都有3種狀況,分別為 pending(未完成)、resolved(已完成,成功)、rejected(已拒絕,失敗)。下面再來看看如何添加回調。

showMsg().then(function( str ){

// 回調添加到這里來了

callback( str );

});

這樣就將回調函數(shù)和原來的異步函數(shù)徹底的星散了,從代碼組織上看,優(yōu)雅了許多。resolve 接受一個參數(shù),該參數(shù)就可以輕松實現(xiàn)將數(shù)據(jù)傳送給使用 then 方法添加的回調中。

對于 ajax 請求,easy.js 直接將 ajax 方法封裝成了 promise 對象,可以直接添加 then 方法往返調。

E.ajax({

url : ‘test1.php’,

type : ‘GET’

})

then(function(){

// 添加請求成功的回調

}, function(){

// 添加請求失敗的回調

});

then 方法接受2個函數(shù)作為參數(shù),個函數(shù)是已完成的回調,第二個就是已失敗的回調。

假如有上面提到的多個 ajax 請求的情況呢?那么就要用到 when 這個方法了。該方法可以接受多個 promise 實例作為參數(shù)。

var requests = E.when(E.ajax({

url : ‘test1.php’,

type : ‘GET’

}), E.ajax({

url : ‘test2.php’,

type : ‘GET’

}));

requests.then(function( arg1, arg2 ){

console.log( ‘success:’ + arg1[0] + arg2[0] );

}, function( arg1, arg2 ){

console.log( ‘failure:’ + arg1 + arg2 );

});

when 方法是將多個 promise 實例存到一個數(shù)組中,等到該數(shù)組的所有 promise 實例都是已完成狀況才去執(zhí)行已完成的回調,一旦有一個實例是已拒絕的狀況,則立即執(zhí)行已拒絕的回調。

Promise 模式是 CommonJS 的規(guī)范之一。許多主流的 javascript 庫都有響應的實現(xiàn),如 jQuery 和 Dojo 中,都有 Deferred 去實現(xiàn)這些功能。在這里照舊要吐槽下 jQuery 的 Deferred,撇開其內部使用,這應該用戶使用率好低的一個模塊了,這和其較復雜的使用體例有一定的關系。

假如你想深入的研究 easy.js 的 promise 源碼,可以查看點擊這兒的鏈接。

文章來源:夜雨帶刀博客

當前標題:使用Promise模式來簡化javascript的異步回調
本文路徑:http://www.rwnh.cn/news5/287955.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站ChatGPT、域名注冊、響應式網(wǎng)站、App設計、關鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運營
宁阳县| 陵水| 宜君县| 赞皇县| 当阳市| 彭阳县| 武川县| 长白| 衡阳市| 罗山县| 东港市| 明星| 永和县| 陇川县| 亳州市| 汝阳县| 建水县| 墨竹工卡县| 阿拉善右旗| 镇赉县| 正宁县| 马龙县| 新闻| 济宁市| 霸州市| 彭州市| 邵武市| 德兴市| 岗巴县| 凉城县| 青河县| 连州市| 九寨沟县| 吉木乃县| 南投市| 永新县| 许昌市| 嘉峪关市| 平谷区| 梁山县| 沙湾县|