setTimeout(function () { console.log(1) }, 0); new Promise(function executor(resolve) { resolve(); }).then(function () { console.log(2); });
如上程式碼,為什麼運行結果是2,1而不是1,2? 不是setTimeout先加入任務佇列嗎?
拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...
從規範上來講,setTimeout有一個4ms的最短時間,也就是說不管你設定多少,反正最少都要間隔4ms才運行裡面的回調(當然,瀏覽器有沒有遵守這個規範是另外一回事兒)。而Promise的非同步就沒有這個問題。
setTimeout
Promise
從具體實現上來說,這兩個的非同步隊列不一樣,Promise所在的那個非同步隊列優先權要高一些。 具體的你可以看這篇文章:從Promise來看JavaScript中的Event Loop、Tasks和Microtasks
Promise的任務會在當前事件循環末尾中執行,而setTimeout中的任務是在下一次事件循環執行
建議你去看下,>中1.5節左右的內容,就理解了~我之前就是看了這個理解的。
從規範上來講,
setTimeout
有一個4ms的最短時間,也就是說不管你設定多少,反正最少都要間隔4ms才運行裡面的回調(當然,瀏覽器有沒有遵守這個規範是另外一回事兒)。而Promise
的非同步就沒有這個問題。從具體實現上來說,這兩個的非同步隊列不一樣,
Promise
所在的那個非同步隊列優先權要高一些。具體的你可以看這篇文章:從Promise來看JavaScript中的Event Loop、Tasks和Microtasks
Promise
的任務會在當前事件循環末尾中執行,而setTimeout
中的任務是在下一次事件循環執行建議你去看下,>中1.5節左右的內容,就理解了~我之前就是看了這個理解的。