ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

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

2021-11-08 11:31:57  阅读:91  来源: 互联网

标签:resolve console log JS Promise return data 请求


        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)])
        })
        .then((res)=>{
            console.log(res,'结束了')
        })

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

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

标签:resolve,console,log,JS,Promise,return,data,请求
来源: https://blog.csdn.net/SW43464616/article/details/121204168

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有