JS 利用Promise去控制一次发起固定数量的请求

        const p1 = (data) => {
            return new Promise((resolve, reject) => {
                setTimeout(() => {
                    resolve(data + 1)
                    console.log('s1')
                }, 1000)
                console.log('p1 finished')
            })
        }
        const p2 = (data) => {
            return new Promise((resolve, reject) => {
                setTimeout(() => {
                    reject(data + 1)
                    console.log('s2')
                }, 2000)
                console.log('p2 finished')
            })
        }
        const p3 = (data) => {
            return new Promise((resolve, reject) => {
                setTimeout(() => {
                    resolve(data + 1)
                    console.log('s3')
                }, 3000)
                console.log('p3 finished')
            })
        }
        const p4 = (data) => {
            return new Promise((resolve, reject) => {
                setTimeout(() => {
                    resolve(data + 1)
                    console.log('s4')
                }, 4000)
                console.log('p4 finished')
            })
        }
        Promise.allSettled([p1(1),p2(2)])
        .then((res)=>{
            console.log(res)
            return Promise.all([p3(3),p4(4)])
        })
        .finally((res)=>{
            console.log(res,'结束了')
        })

这里大家需要注意的是为什么不同 Promise.all  这个方法,因为众所周知这个方法也是等待Promise传入的Promise对象数组中的每一个Promise执行完毕,但是这个方法有一个弊端就是如果其中有一个Promise的状态为reject那么就会走到catch分支,那么导致的后果就是无法拿到另外的resolve的值,而且需要多写一层.finally去return下一次的 Promise.all ,这样就导致要写很多没用的分支去保证每一次都能有返回值,并且可能丢失部分返回值;

Promise.allSettled 这个方法无论其数组参数中的Promise对象是否全是resolve,都会进入.then分支,只不过对于其.then接收的参数不同,不过都是一个数组形式的返回,具体是什么复制一下我上面的代码,然后打印一下就知道了,这里就不做过多赘述,程序员最忌讳眼高手低,相信我,多去练习!

一定要注意!!!!!!!

这里的 Promise.allSettled 低版本的IE不兼容

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值