理解
Promise.all等待所有Promise執行完畢之後,按照放在all中的先後順序將resolve()返回的數據放在Promise.all的resolve中,說也說不明白,寫個栗子吧。。。
栗子
// 方法a,返回一個Promise對象
function a() {
return new Promise((r, j) => {
setTimeout(() => {
console.log('a')
r('a')
}, 3000)
})
}
// 方法b,返回一個Promise對象
function b() {
return new Promise((r, j) => {
setTimeout(() => {
console.log('b')
r('b')
}, 1000)
})
}
Promise.all([a(), b()]).then(r => {
console.log(r)
})
// 輸出情況
b
a
['a', 'b']
由此栗子可以看出,all()中的Promise對象執行先後順序由自己快慢控制,全部執行完畢後,按照放入all()的先後順序放入Promise.all().then®的r中。