久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:126日期:2023-05-15 09:32:56

問題描述

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

如上代碼,為什么運行結果是2,1而不是1,2?不是setTimeout先加入任務隊列嗎?

問題解答

回答1:

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

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

回答2:

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

回答3:

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

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

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 西林县| 平邑县| 江门市| 苍梧县| 金平| 建昌县| 阿拉善盟| 宁蒗| 茂名市| 海盐县| 金平| 大冶市| 靖宇县| 临沧市| 辽阳市| 广安市| 汉沽区| 泰宁县| 新津县| 伊吾县| 大庆市| 嘉鱼县| 大埔区| 沿河| 黑龙江省| 德化县| 兖州市| 枝江市| 保康县| 山东省| 会昌县| 上蔡县| 蒙山县| 南安市| 包头市| 道真| 英德市| 武义县| 遂川县| 高平市| 双柏县|