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

Promise.all中對于reject的處理方法

 更新時間:2018年08月01日 16:24:32   作者:huanglei-  
這篇文章主要介紹了Promise.all中對于reject的處理方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下

昨天寫了個小爬蟲,用axios.all同時請求多個頁面時,國內(nèi)網(wǎng)絡(luò)的原因很容易就超時然后reject了,佛系resolve不可取啊,然后想到可以實現(xiàn)一個“重發(fā)失敗請求”的功能。

Promise.all(requestPromises).then(...).catch(...) 會在所有requestPromises都resolve時才會進then方法,并且把所有結(jié)果以一個數(shù)組返回。只要有一個失敗,就會進catch。如果在單個請求中定義了catch方法,那么就不會進Promise.all的catch方法。因此,可以在單個的catch中將失敗的promise放入一個list,待一輪請求完成后,再去請求失敗的請求。

let failedList = []
function getDataById (id) { // 這是單個請求
 return new Promise(function (resolve, reject) {
  getResponse(id, resolve, reject)
 }).catch(e => {
  failedList.push(arguments.callee(id)) // 如果失敗,就重新發(fā)起請求,并將該請求的promise放入failedList中以便后續(xù)處理
 })
}
function getResponse (id, resolve, reject) { // 模擬返回結(jié)果
 setTimeout(() => {
  if (Math.random() > 0.8) resolve({id, msg: 'ok'})
  else reject({id, msg: 'error'})
 }, 1000)
}
const RequestList = [getDataById(1), getDataById(2), getDataById(3)]
fetchData(RequestList)
let counter = 1 // 請求次數(shù)
let maxRequestTimes = 5 // 最大請求次數(shù),因為有可能別個頁面就是訪問不了,請求多少次也沒用- - 
let result = [] // 最后的結(jié)果
function fetchData (requestList) { // 這里是對請求結(jié)果的處理
 Promise.all(requestList).then(resolve => {
  result = result.concat(resolve.filter(i => i)) // filter返回true的時候保留該數(shù)組項,因為getDataById的catch里沒有給返回值(這里也不需要),這里的resolve里就會有undefined,需要過濾掉
  let failedLength = failedList.length
  if (failedLength > 0 && counter < maxRequestTimes) { // 如果失敗列表里有請求,并且請求次數(shù)不超過設(shè)定的值,就進行下一次請求,并且打出log
   console.log(`第${counter}次請求完成,其中成功${RequestList.length - failedLength}個,失敗${failedLength}個,正在進行第${++counter}次請求...`)
   fetchData(failedList)
   failedList = [] // 這里要清空failedList,不然會一直調(diào)用。不用擔(dān)心,下一次請求失敗的會在getDataById填充到failedList里。
  } else { // 表示所有請求都成功了,或者達到了最大請求次數(shù)。到這里就可以對result做進一步處理了。
   console.log(`請求完成,共請求${counter}次, 其中成功${RequestList.length - failedLength}個,失敗${failedLength}個\n`, result)
   counter = 1
  }
 }).catch(e => {
  console.log(e)
 })
}

總結(jié)

以上所述是小編給大家介紹的Promise.all中對于reject的處理方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

最新評論