promise 并发请求-Promise.all()/Promise.allSettle()

方法定义

//request.js 定义
export function all(requests, callback) {
  Promise.all(requests)
    .then(params => callback(params))
    .catch(error => {
      console.error(error)
    })
}
export function allSettle(requests, callback) {
  Promise.allSettled(requests)
    .then(params => callback(params))
    .catch(error => {
      console.error(error)
    })
}

方法使用


import {  allSettle } from '@/utils/request'

export function dashboardData(params, callback) {
  let requests = [
    // post/get 请求组成的promise 数组
  ]
  allSettle(requests, callback)
  // all(requests, callback)
}

方法区别

  • Promise.all 方法请求中所有结果都成功则返回有结果组成的数组,其中一个失败立马返回失败,不继续执行
  • Promise.allSettled 方法执行完数组中所有方法 统一返回结果,不管成功或者失败都会返回。
//状态值 fulfilled(成功),rejected(失败)
[{status:'fulfilled',value:{data:接口返回的值}}] 
posted @ 2023-08-25 13:49  巫小婆  阅读(162)  评论(0编辑  收藏  举报