Javascript中Promise的四種常用方法總結(jié)
前言
Promise是JavaScript異步操作解決方案,最近看到項(xiàng)目里不少人用了Promise 的庫(kù)類,比如 bluebird、q 、jQuery.Deffered 等 polyfill promise 方式,使用的時(shí)候翻看長(zhǎng)長(zhǎng)的文檔,真心累覺(jué)不愛。
es5 發(fā)展到現(xiàn)在,node 在0.12版本就已經(jīng)支持了promise, 在客戶端,大部分瀏覽器也支持了Promise, 如果要兼容低版本的瀏覽器,可以加上es5-shim等 polyfill promise。下面話不多說(shuō),來(lái)一起看看詳細(xì)的介紹:
用法
Promise 常用場(chǎng)景。
- 處理異步回調(diào)
- 多個(gè)異步函數(shù)同步處理
- 異步依賴異步回調(diào)
- 封裝統(tǒng)一的入口辦法或者錯(cuò)誤處理
一、處理異步回調(diào)
Promise 的基本用法, 處理異步回調(diào)。
function Pro1(){ return new Promise(function(resolve, reject) { setTimeout(function(){ resolve('pro1') }, 300) }) } //調(diào)用 Pro1() .then(function(data){ console.log(data) //pro1 }) .catch(function(err){ throw new Error(err) })
二、多個(gè)異步函數(shù)同步處理
有時(shí)候我們需要發(fā)送兩個(gè)ajax,希望他們能一起把數(shù)據(jù)返回,就可以采用下面的辦法。
function Pro1(){ return new Promise(function(resolve, reject) { setTimeout(function(){ resolve('pro1') }, 300) }) } function Pro2(){ return new Promise(function(resolve, reject) { setTimeout(function(){ resolve('pro2') }, 300) }) } //調(diào)用 var Pro = Promise.all([Pro1(), Pro2()]); Pro .then(function(data){ console.log(data[0], data[1]) //Pro1 Pro2 }) .catch(function(err){ throw new Error(err) })
三、異步依賴異步回調(diào)
有些場(chǎng)景是一個(gè)異步依賴另一個(gè)異步的返回值的,就可以采用下面的用法。
比如: 用一個(gè)訂單號(hào)異步取到訂單詳情,再用訂單詳情里的商品Id獲取到商品詳情。
function Pro1(orderId){ return new Promise(function(resolve, reject) { setTimeout(function(){ var orderInfo = { orderId: orderId, productIds: ['123', '456'] } resolve(orderInfo.productIds) }, 300) }) } function Pro2(productIds){ return new Promise(function(resolve, reject) { setTimeout(function(){ var products = productIds.map(function(productId){ return { productId: productId, name: '衣服' } }) resolve(products) }, 300) }) } //調(diào)用 Pro1('abc123') .then(function(productIds){ console.log('商品id',productIds) return Pro2(productIds) }) .then(function(products){ console.log('商品詳情',products) }) .catch(function(err){ throw new Error(err) })
四、封裝統(tǒng)一的入口辦法或者錯(cuò)誤處理
錯(cuò)誤處理
function ErrorHandler(promiseObj, rejectOrResOrCallback){ return promiseObj.then(null, function(err){ if(!err) }) }
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
JavaScript分秒倒計(jì)時(shí)器實(shí)現(xiàn)方法
這篇文章主要介紹了JavaScript分秒倒計(jì)時(shí)器實(shí)現(xiàn)方法,可實(shí)現(xiàn)按照毫秒倒計(jì)時(shí)的效果,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-02-02基于HTML5+JS實(shí)現(xiàn)本地圖片裁剪并上傳功能
這篇文章主要為大家詳細(xì)介紹了HTML5本地圖片裁剪并上傳的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03ES6新特性之類(Class)和繼承(Extends)相關(guān)概念與用法分析
這篇文章主要介紹了ES6新特性之類(Class)和繼承(Extends)相關(guān)概念與用法,結(jié)合實(shí)例形式較為詳細(xì)的分析了ES6中類(Class)和繼承(Extends)的基本概念、語(yǔ)法、使用方法與注意事項(xiàng),需要的朋友可以參考下2017-05-05微信公眾平臺(tái)獲取access_token的方法步驟
這篇文章主要介紹了微信公眾平臺(tái)獲取access_token的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03JavaScript數(shù)組去重的方法總結(jié)【12種方法,號(hào)稱史上最全】
這篇文章主要介紹了JavaScript數(shù)組去重的方法,結(jié)合實(shí)例形式較為詳細(xì)的總結(jié)分析了12種方法數(shù)組去重的方法,需要的朋友可以參考下2019-02-02