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) 不返回任何值,默認返回當(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聊天消息展示和評論提交功能
這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)QQ聊天消息展示和評論提交功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05深入理解Javascript中的循環(huán)優(yōu)化
這篇文章介紹了Javascript中的循環(huán)優(yōu)化,有需要的朋友可以參考一下2013-11-11用最簡單的方法判斷JavaScript中this的指向(推薦)
都說 JavaScript 是一種很靈活的語言,這其實也可以說它是一個混亂的語言,下面通過本文給大家分享JavaScript中this的指向知識,感興趣的朋友一起看看吧2017-09-09