欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

如何使用Promise模式來(lái)簡(jiǎn)化JavaScript的異步回調(diào)

2024-01-06    分類(lèi): 網(wǎng)站建設(shè)

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

先看看下面這個(gè)常見(jiàn)的異步函數(shù)。

var showMsg = function(){

setTimeout(function(){

alert( ‘hello’ );

}, 5000 );

};

如果要給該函數(shù)添加回調(diào),通常會(huì)這么干。

var showMsg = function( callback ){

setTimeout(function(){

alert( ‘hello’ );

// 此處添加回調(diào)

callback();

}, 5000 );

};

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

var showMsg = function(){

// 構(gòu)造promise實(shí)例

var promise = new E.Promise();

setTimeout(function(){

alert( ‘hello’ );

// 改變promise的狀態(tài)

promise.resolve( ‘done’ );

}, 5000 );

// 返回promise實(shí)例

return promise;

};

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

showMsg().then(function( str ){

// 回調(diào)添加到這里來(lái)了

callback( str );

});

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

對(duì)于 ajax 請(qǐng)求,easy.js 直接將 ajax 方法封裝成了 promise 對(duì)象,可以直接添加 then 方法來(lái)回調(diào)。

E.ajax({

url : ‘test1.php’,

type : ‘GET’

})

then(function(){

// 添加請(qǐng)求成功的回調(diào)

}, function(){

// 添加請(qǐng)求失敗的回調(diào)

});

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

如果有上面提到的多個(gè) ajax 請(qǐng)求的情況呢?那么就要用到 when 這個(gè)方法了。該方法可以接受多個(gè) promise 實(shí)例作為參數(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 方法是將多個(gè) promise 實(shí)例存到一個(gè)數(shù)組中,等到該數(shù)組的所有 promise 實(shí)例都是已完成狀態(tài)才去執(zhí)行已完成的回調(diào),一旦有一個(gè)實(shí)例是已拒絕的狀態(tài),則立即執(zhí)行已拒絕的回調(diào)。

Promise 模式是 CommonJS 的規(guī)范之一。很多主流的 JavaScript 庫(kù)都有相應(yīng)的實(shí)現(xiàn),如 jQuery 和 Dojo 中,都有 Deferred 去實(shí)現(xiàn)這些功能。在這里還是要吐槽下 jQuery 的 Deferred,撇開(kāi)其內(nèi)部使用,這應(yīng)該用戶使用率最低的一個(gè)模塊了,這和其較復(fù)雜的使用方式有一定的關(guān)系。

分享標(biāo)題:如何使用Promise模式來(lái)簡(jiǎn)化JavaScript的異步回調(diào)
當(dāng)前地址:http://aaarwkj.com/news42/312242.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護(hù)云服務(wù)器、網(wǎng)站內(nèi)鏈、靜態(tài)網(wǎng)站域名注冊(cè)、面包屑導(dǎo)航

廣告

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

成都定制網(wǎng)站建設(shè)
高潮内射主播自拍一区| 亚洲欧美中文日韩一区| 午夜少妇福利在线观看| 欧美v日韩v亚洲综合国产高清| 欧美一区二区三区人妻熟妇| 人人妻人人澡人人爽人人老司机| 久久99热最新地址获取| 久国产精品久久久极品| 亚洲情欲一级片日韩欧美| 亚洲国产精品综合久久久| 漂亮人妻少妇中文字幕| 91天美精东果冻麻豆| 人妻内射一区二区在线视| 国产在线自拍一区二区| 久久热这里只有精品网站| 国产级一片内射视步页| 91免费在线观看高清| 国产一区黄片视频在线观看| 亚洲欧美日韩午夜在线| 人人妻人人澡人人爽精品日本| 高潮的毛片激情久久精品| 全国最大成人免费视频| 日韩亚洲一区在线观看| 国产精品亚洲视频欧美视频| av二区不卡国产精品| 国产av麻豆全部免费| 一区二区三区不卡中文字幕| 国产高清av免费观看| 欧美老熟妇精品一区二区| 久久精品视频视频视频| 亚洲精品一区二区免费看| 麻豆国产国语精品三级在线观看| 久久国产福利一区二区| 日韩成人高清免费在线| 国产另类极品熟女露脸自拍| 日本人妻丰满熟妇久久| 大香蕉一区二区亚洲欧美| 日本高清av一区二区| 日韩免费精品一区二区| 粉嫩美女精品一区二区| 97视频在线观看网站|