第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

JS promise 執(zhí)行順序

JS promise 執(zhí)行順序

qq_遁去的一_1 2019-02-05 16:31:15
var p2 = new Promise(resolve => {   setTimeout(() => {     resolve()   }, 2000) })var p1 = new Promise(resolve => {   resolve(p2) }) p1.then(data => {  console.log('p1') }) p2.then(data => {  console.log('p2')  console.log('p1 status ', p1) // 這里在瀏覽器輸出的是 pending 狀態(tài)   Promise.resolve().then(() => {    console.log('here') // 然后這里會優(yōu)先于 p1.then() 輸出   }) })請問一下,p1 的狀態(tài)到底什么時候才會改變呢?為什么執(zhí)行到 console.log('p1 status ', p1) 時候,p1 的狀態(tài)是 pending 呢?萬分感謝~
查看完整描述

1 回答

?
POPMUISE

TA貢獻1765條經驗 獲得超5個贊

Promise里提供的resolve、reject參數是異步的,所以會晚于同步代碼。

如果resolve函數里的參數是一個Promise實例,那么會等待這個實例的狀態(tài)改變后才會改變狀態(tài)。所以p1.then里的函數最后執(zhí)行,因為p1的狀態(tài)要等p2的狀態(tài)確定后才能改變,所以執(zhí)行到 console.log('p1 status ', p1) 時候,p1 還沒有改變狀態(tài)。

不好理解的話,我之前寫了個Promise實現,你對比著上面的話看下。學習并實現一個Promise


查看完整回答
反對 回復 2019-02-05
  • 1 回答
  • 0 關注
  • 475 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號