亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Javascript中Promise的四種常用方法總結(jié)

 更新時(shí)間:2017年07月14日 09:03:28   作者:combine  
這篇文章主要給大家總結(jié)介紹了關(guān)于Javascript中Promise的四種常用方法,分別是處理異步回調(diào)、多個(gè)異步函數(shù)同步處理、異步依賴異步回調(diào)和封裝統(tǒng)一的入口辦法或者錯(cuò)誤處理,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。

前言

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)文章

最新評(píng)論