Promise.all執行順序

Promise.all執行順序

理解

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中。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章