首頁  >  問答  >  主體

javascript - promise和setTimeout執行順序的疑惑

setTimeout(function () {
    console.log(1)
}, 0);
new Promise(function executor(resolve) {
        resolve();
}).then(function () {
    console.log(2);
});

如上程式碼,為什麼運行結果是2,1而不是1,2?
不是setTimeout先加入任務佇列嗎?

高洛峰高洛峰2673 天前1132

全部回覆(3)我來回復

  • 黄舟

    黄舟2017-06-26 10:59:47

    從規範上來講,setTimeout有一個4ms的最短時間,也就是說不管你設定多少,反正最少都要間隔4ms才運行裡面的回調(當然,瀏覽器有沒有遵守這個規範是另外一回事兒)。而Promise的非同步就沒有這個問題。

    從具體實現上來說,這兩個的非同步隊列不一樣,Promise所在的那個非同步隊列優先權要高一些。
    具體的你可以看這篇文章:從Promise來看JavaScript中的Event Loop、Tasks和Microtasks

    回覆
    0
  • 某草草

    某草草2017-06-26 10:59:47

    Promise的任務會在當前事件循環末尾中執行,而setTimeout中的任務是在下一次事件循環執行

    回覆
    0
  • 淡淡烟草味

    淡淡烟草味2017-06-26 10:59:47

    建議你去看下,<<你不知道的js(中卷)>>中1.5節左右的內容,就理解了~我之前就是看了這個理解的。

    回覆
    0
  • 取消回覆