Promise.all可以将多个Promise实例包装成一个新的Promise实例。同时,成功和失败的返回值是不同的,成功的时候返回的是一个结果数组,而失败的时候则返回最先被reject失败状态的值。
let promise1= new Promise((resolve, reject) => {
setTimeout(() => {
resolve({"id": "1001", "sex": "男"})
}, 2000)
})
let promise2= new Promise((resolve, reject) => {
setTimeout(() => {
resolve({"id": "1001", "age": 30})
}, 1000)
})
Promise.all([ promise1, promise2]).then(res=>{
console.log(res)
// [{ "id": "1001", "sex": "男"}, { "id": "1001", "age": 30}]
})
Promse.all在处理多个异步处理时非常有用,比如说一个页面上需要等两个或多个ajax的数据回来以后才正常显示
遍历发送请求
let arr=[{id:"123",name:"张三",age:"30",sex:"男"},{id:"124",name:"李四",age:"29",sex:"男"}]
fun(){
let arr1=arr.map(item=>{
return new Promise((resolve, reject) => {
const res = await axios({
url: '/fina/user',
method: 'get',
params: { id: item.id},
})
if(res.success){
resolve(res)
}else{
reject('操作失败')
}
})
Promise.all(arr1).then((resoult) => {})
}