原文:Promise里的代碼為什么比setTimeout先執行

當瀏覽器或者Node拿到一段代碼時首先做的就是傳遞給JavaScript引擎,並且要求它去執行。 然而,執行 JavaScript 並非一錘子買賣,宿主環境當遇到一些事件時,會繼續把一段代碼傳遞給 JavaScript 引擎去執行,此外,我們可能還會提供 API 給 JavaScript 引擎,比如 setTimeout 這樣的 API,它會允許 JavaScript 在特定的時機執行。 所以,我 ...

2019-06-13 14:17 0 622 推薦指數:

查看詳情

重學前端 --- Promise代碼為什么比setTimeout執行

首先通過一段代碼進入討論的主題 了解過 Promise 對象的都知道(如果還不了解,可以查看 Promise對象),Promise 新建后會立即執行,所以首先會輸出a,這個沒有問題。setTimeout 和 then 這兩個回調函數會在本輪事件循環結束以后執行,所以第二個輸出的是b ...

Wed Apr 24 00:11:00 CST 2019 0 1786
PromisesetTimeout執行順序

1、示例 2、解釋 最需要 解釋的是:then和settimeout執行順序,即setTimeout(fn, 0)在下一輪“事件循環”開始時執行Promise.then()在本輪“事件循環”結束時執行。因此then 函數輸出,settimeout后輸出 ...

Tue May 05 20:16:00 CST 2020 0 1668
promisesetTimeout執行順序的問題

提出問題,問題代碼為 在控制台運行其結果為: 疑問:既然promise.then和setTimeout都是異步的,那么在事件循環隊列中 promise.then的事件應該排在setTimeout后面,那為什么promise.then卻在setTimeout前面被打 ...

Tue Dec 25 00:07:00 CST 2018 0 684
關於setTimeoutPromise執行順序問題

先看一段代碼 執行結果: 可以看出PromisesetTimeout()執行。 因為Promise定義之后便會立即執行,其后的.then()是異步里面的微任務。 而setTimeout()是異步的宏任務。 引自https ...

Fri Aug 31 19:21:00 CST 2018 0 6193
promise.then, setTimeout,await執行順序問題

promise.then VS setTimeout   在chrome和node環境環境中均輸出2, 3, 1, 輸出2沒什么好說的,3和1順序讓人有些意外 原因: 有一個事件循環,但是任務隊列可以有多個。 整個script代碼,放在了macrotask ...

Fri Jun 22 06:46:00 CST 2018 0 4070
js--->setTimeoutPromise執行順序

setTimeout(function() { console.log(1) }, 0); new Promise(function(resolve, reject) { console.log(2) for (var i = 0; i < 10000; i++) { if(i ...

Wed Dec 04 18:45:00 CST 2019 0 638
js 關於setTimeoutPromise執行順序問題

js 關於setTimeoutPromise執行順序問題 異步 -- PromisesetTimeout 執行順序 PromisesetTimeout 到底誰先執行 定時器的介紹 ...

Sat Feb 08 01:03:00 CST 2020 0 1252
setTimeoutPromise、Async/Await 的執行順序

 Javascript 有一個 main thread 主線程和 call-stack 調用棧(執行棧),所有的任務都會被放到調用棧等待主線程執行。 JS調用棧采用的是后進先出的規則,當函數執行的時候,會被添加到棧的頂部,當執行執行完成后,就會從棧 ...

Thu Aug 15 09:50:00 CST 2019 0 813
 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM