JavaScript promise的使用和原理分析
一、為什么一個promise可以調(diào)用多個.then方法
如下面的:
const promise = new Promise((resolve, reject) => {
resolve("hahaha")
})
// 1.同一個Promise可以被多次調(diào)用then方法
// 當(dāng)我們的resolve方法被回調(diào)時, 所有的then方法傳入的回調(diào)函數(shù)都會被調(diào)用
promise.then(res => {
console.log("res1:", res) //hahaha
})
promise.then(res => {
console.log("res2:", res) //hahaha
})
promise.then(res => {
console.log("res3:", res) //hahaha
})
答案:
- then內(nèi)回調(diào) 不返回任何值,默認(rèn)返回當(dāng)前Promise
- then內(nèi)回調(diào) 返回Promise
- then內(nèi)回調(diào) 返回 普通值(數(shù)值/字符串/普通對象/undefined),普通的值被作為一個新的Promise的resolve值
二、什么是Promise.resolve()
Promise.resolve() 表示狀態(tài)為fulfilled的promise對象
Promise.resolve()
// 等同于
new Promise((resolve)=>{resolve()})
為什么會有下面的執(zhí)行結(jié)果? 感覺十分異常
Promise.resolve().then(() => {
console.log(0);
return Promise.resolve(4)
}).then(res => {
console.log(res)
})
Promise.resolve().then(() => {
console.log(1);
}).then(() => {
console.log(2);
}).then(() => {
console.log(3);
}).then(() => {
console.log(5);
}).then(() =>{
console.log(6);
})
// 0,1,2,3,4,5,6
(
async function() {
return Promise.resolve()
}
)().then(()=>{
console.log(1)
})
new Promise((resolve) => {
resolve()
}).then(()=>{
console.log(2)
}).then(()=>{
console.log(3)
})
/// 2 3 1
答案:
如果promise內(nèi)返回的對象具有可調(diào)用的then方法,則會在微任務(wù)隊列中再插入一個任務(wù)NewPromiseResolveThenableJob,這就慢了一拍;這個任務(wù)會執(zhí)行這個then方法,如果這個then方法是來自于promise的,則因為是異步的又慢了一拍,所以一共慢了兩拍。
三、Promise.all缺陷和Promise.allSettled
Promise.all() 的缺陷
其中任意一個 promise 被 reject ,Promise.all 就會立即被 reject ,不在執(zhí)行then。
數(shù)組中其它未執(zhí)行完的 promise 依然是在執(zhí)行的,但是Promise.all 沒有返回它們的結(jié)果,同時Promise.all 沒有采取任何措施來取消它們的執(zhí)行。
Promise.allSettled()
Promise.allSettled() 可以獲取數(shù)組中每個 promise 的結(jié)果,無論成功或失敗
只有then方法 所有結(jié)果都會在then中體現(xiàn)
注意
彼此相互依賴,一個失敗全部失效(全無或全有)用 Promise.all ;相互獨立,獲取每個結(jié)果用 Promise.allSettled
四、Promise.race() 使用
多個promise執(zhí)行,最快的執(zhí)行Promise.race()的then或者catch
里面的promise依舊會執(zhí)行
const promise1 = new Promise((resolve, reject) => {
setTimeout(() => {
resolve('Promise 1 resolved');
console.log(0)
}, 1000);
});
const promise2 = new Promise((resolve, reject) => {
setTimeout(() => {
console.log(2)
resolve('Promise 2 resolved');
}, 2000);
});
Promise.race([promise1, promise2]).then(result => {
console.log(result); // "Promise 1 resolved"
});
// 0
//Promise 1 resolved
//2
到此這篇關(guān)于JavaScript promise的使用和原理分析的文章就介紹到這了,更多相關(guān)JS promise內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript實現(xiàn)QQ聊天消息展示和評論提交功能
這篇文章主要為大家詳細(xì)介紹了JavaScript實現(xiàn)QQ聊天消息展示和評論提交功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05
前端進(jìn)階之教你利用javascript存儲函數(shù)
這篇文章主要給大家介紹了關(guān)于利用javascript存儲函數(shù)的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用js具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2021-11-11
深入理解Javascript中的循環(huán)優(yōu)化
這篇文章介紹了Javascript中的循環(huán)優(yōu)化,有需要的朋友可以參考一下2013-11-11
用最簡單的方法判斷JavaScript中this的指向(推薦)
都說 JavaScript 是一種很靈活的語言,這其實也可以說它是一個混亂的語言,下面通過本文給大家分享JavaScript中this的指向知識,感興趣的朋友一起看看吧2017-09-09

