美女91-美女18一级毛片免费看-美女18毛片免费视频-美女18毛片-美乃雀中文字幕在线一区-美美女高清毛片视频免费观看

蒙狼科技logo
設(shè)為首頁| 聯(lián)系我們
咨詢熱線: 13917498722
  您的位置: 首頁 > 網(wǎng)站資訊 > 使用Promise模式來簡化javascript的異步回調(diào)

使用Promise模式來簡化javascript的異步回調(diào)

發(fā)布日期:2017/6/19

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

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

先看看下面這個(gè)常見的異步函數(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的狀況

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 的狀況為已完成,第三步就是返回這個(gè) promise 實(shí)例。每個(gè) promise 實(shí)例都有3種狀況,分別為 pending(未完成)、resolved(已完成,成功)、rejected(已拒絕,失敗)。下面再來看看如何添加回調(diào)。

showMsg().then(function( str ){

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

callback( str );

});

這樣就將回調(diào)函數(shù)和原來的異步函數(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 方法往返調(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í)例都是已完成狀況才去執(zhí)行已完成的回調(diào),一旦有一個(gè)實(shí)例是已拒絕的狀況,則立即執(zhí)行已拒絕的回調(diào)。

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

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

文章來源:夜雨帶刀博客





其他相關(guān)文章
  • 蘋果Swift語言開源了!附下載地址
  • 網(wǎng)站建設(shè)之如何提高網(wǎng)站權(quán)重?
  • 對(duì)IP和子網(wǎng)掩碼的一點(diǎn)粗淺熟悉
  • 叱咤風(fēng)云!20個(gè)史詩級(jí)的大屏全景網(wǎng)站設(shè)計(jì)
  • 網(wǎng)絡(luò)推廣渠道有哪些
  • 網(wǎng)站打不開的緣故原由有解決方法了




  • 企業(yè)網(wǎng)站后臺(tái)使用
    購物網(wǎng)站后臺(tái)使用
    網(wǎng)站產(chǎn)品圖片的處理



    農(nóng)業(yè)銀行支付
    建設(shè)銀行支付
    郵政儲(chǔ)蓄銀行支付



    企業(yè)網(wǎng)站建設(shè)
    整站建設(shè)
    購物網(wǎng)站



    企業(yè)網(wǎng)站建設(shè)建議
    注冊(cè)適合自己的域名
    什么是虛擬主機(jī)




    售前咨詢QQ: 838821345
    售后服務(wù)QQ: 464698733
    應(yīng)急手機(jī):13917498722


    微信掃一掃
    添加24小時(shí)微信客服


    郵箱:lang@MENGL.CN
    地址:上海寶山區(qū)城銀路555弄2號(hào)樓3樓
    ICP備案:滬ICP備12042844號(hào)-3
     滬公網(wǎng)安備:31011402002917號(hào)
    做網(wǎng)站 | 企業(yè)網(wǎng)站建設(shè) | 上海做網(wǎng)站 | 企業(yè)網(wǎng)站制作 | 做網(wǎng)站的公司 | 關(guān)于蒙狼 | 整站建設(shè) | 購物網(wǎng)站 | 企業(yè)網(wǎng)絡(luò)營銷 | 成功案例 | 加盟代理 | 在線訂單
    服務(wù)區(qū)域: 臨港新區(qū)做網(wǎng)站 徐匯做網(wǎng)站 閔行做網(wǎng)站 長寧做網(wǎng)站 虹口做網(wǎng)站 黃浦做網(wǎng)站 盧灣做網(wǎng)站 靜安做網(wǎng)站 浦東做網(wǎng)站 楊浦做網(wǎng)站 普陀做網(wǎng)站 閘北做網(wǎng)站 寶山做網(wǎng)站 嘉定做網(wǎng)站 松江做網(wǎng)站 昆山做網(wǎng)站
    Copyright 2012-2025 上海蒙狼網(wǎng)絡(luò)科技有限公司 aqdzp.cn All Rights Reserved
    主站蜘蛛池模板: 国产自在自线午夜精品视频在 | 二区不卡 | 欧美国产精品主播一区 | 中国特级黄一级真人毛片 | 成人激情在线 | 欧美性性性性性色大片免费的 | 日韩欧美在线视频观看 | 国产成人精品高清免费 | 国产成人精品免费视频大 | 亚洲三级理论 | 国产私拍福利精品视频网站 | 成人亚洲视频 | 日韩精品视频美在线精品视频 | 日韩一区视频在线 | 全彩调教侵犯h本子全彩校花 | 欧美成人三级伦在线观看 | 午夜羞羞视频在线观看 | 欧美亚洲精品在线 | 国产成人精品福利网站人 | 免费的爱爱视频 | 在线观看人成网站深夜免费 | 欧美日韩一级二级三级 | 国产一区二区三区在线观看免费 | 91精品久久国产青草 | 一二三四视频社区在线 | 亚洲美女视频在线观看 | 日韩视频高清 | 亚洲视频观看 | 国产精品亚洲精品不卡 | 曰本一级毛片 | a黄网站| 免费看美女毛片 | 欧美视频在线播放 | 日韩欧美精品综合久久 | 国产一二三区精品 | 欧美日韩免费播放一区二区 | 日韩久久免费视频 | 91av视频在线免费观看 | 亚洲 久久 | 亚洲欧美色综合精品 | 欧美日本一道高清免费3区 欧美日本一道免费一区三区 |