promise的all方法和race

all 方法可以完成并行任务,它接收一个数组,数组的每一项都是一个promise对象

当数组中所有的promise的状态都达到resolved的时候,all方法的状态就会变成resolved,如果有一个状态变成了rejected,那么all方法的状态就会变成rejected。

javascript 复制代码
 // all 方法可以完成并行任务,它接收一个数组,数组的每一项都是一个promise对象
        // 当数组中所有的promise的状态都达到resolved的时候,all方法的状态就会变成resolved,如果有一个状态变成了rejected,那么all方法的状态就会变成rejected。
        window.onload = function () {
            // 在这里编写需要在页面加载完成后执行的代码
            let promise1 = new Promise((resolve, reject) => {
                resolve({
                    code: 200,
                    data: [
                        {
                            weight: 1,
                            name: '测试数据一',
                            sex: '0',
                            status: '正常'
                        },
                        {
                            weight: 2,
                            name: '测试数据二',
                            sex: '1',
                            status: '正常'
                        }
                    ]
                })
            })
            let promise2 = new Promise((resolve, reject) => {
                setTimeout(() => {
                    resolve({
                        code:200,
                        data:[
                            {
                                name:"长官三",
                                age:'18'
                            }
                        ]
                    })
                }, 1000)
            })

            let promise3 = new Promise((resolve, reject) => {
                setTimeout(() => {
                    resolve(3)
                }, 3000)
            })
            Promise.all([promise1, promise2, promise3]).then((res) => {
                console.log(res)
            })
        };

race方法和all一样,接受的参数是一个每项都是promise的数组,但是与all不同的是,当最先执行完的事件执行完之后,就直接返回该promise对象的值。如果第一个promise对象状态变成resolved,那自身的状态变成了resolved;反之第一个promise变成rejected,那自身状态就会变成rejected。

javascript 复制代码
let promise1 = new Promise((resolve,reject)=>{
	setTimeout(()=>{
       reject(
    {
                    code: 200,
                    data: [
                        {
                            weight: 1,
                            name: '测试数据一',
                            sex: '0',
                            status: '正常'
                        },
                        {
                            weight: 2,
                            name: '测试数据二',
                            sex: '1',
                            status: '正常'
                        }
                    ]
                }


);
	},2000)
});
let promise2 = new Promise((resolve,reject)=>{
	setTimeout(()=>{
       resolve(2);
	},1000)
});
let promise3 = new Promise((resolve,reject)=>{
	setTimeout(()=>{
       resolve(3);
	},3000)
});
Promise.race([promise1,promise2,promise3]).then(res=>{
	console.log(res);
	//结果:2
},rej=>{
    console.log(rej)};
)
相关推荐
2501_915918418 分钟前
Web 前端可视化开发工具对比 低代码平台、可视化搭建工具、前端可视化编辑器与在线可视化开发环境的实战分析
前端·低代码·ios·小程序·uni-app·编辑器·iphone
程序员的世界你不懂1 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
索迪迈科技1 小时前
网络请求库——Axios库深度解析
前端·网络·vue.js·北京百思可瑞教育·百思可瑞教育
gnip1 小时前
JavaScript二叉树相关概念
前端
lingchen19061 小时前
MATLAB的数值计算(三)曲线拟合与插值
开发语言·matlab
gb42152872 小时前
java中将租户ID包装为JSQLParser的StringValue表达式对象,JSQLParser指的是?
java·开发语言·python
一朵梨花压海棠go2 小时前
html+js实现表格本地筛选
开发语言·javascript·html·ecmascript
蒋星熠2 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
attitude.x2 小时前
PyTorch 动态图的灵活性与实用技巧
前端·人工智能·深度学习
β添砖java2 小时前
CSS3核心技术
前端·css·css3