首頁 web前端 js教程 setTimeout(..., ) 在 JavaScript 中的真正意義是什麼? (事件循環解釋!)

setTimeout(..., ) 在 JavaScript 中的真正意義是什麼? (事件循環解釋!)

Dec 15, 2024 am 04:07 AM

What Does setTimeout(..., ) Really Mean in JavaScript? (Event Loop Explained!)

setTimeout(..., 0ms) 在 JavaScript 中的真正意義是什麼? (事件循環解釋!)

好吧,讓我們用 0ms 來分解整個 setTimeout 的事情。乍一看,你可能會想,「兄弟,0ms 意味著它會立即運行,對嗎?」但 JavaScript 有它自己的氛圍,0 毫秒並不像你想像的那麼即時。讓我們一起來解決這個問題。


代碼:

這是我們正在剖析的程式碼:

const promise = new Promise((resolve, reject) => {
  console.log(1); 
  setTimeout(() => { 
    console.log("timerStart");
    resolve("success"); 
    console.log("timerEnd");
  }, 0); 
  console.log(2); 
});

promise.then((res) => {
  console.log(res); 
})

console.log(4);
登入後複製

輸出呢?

1  
2  
4  
timerStart  
success  
timerEnd  
登入後複製

大問題:0ms 發生了什麼事?

當你看到setTimeout(() => { ... }, 0) 的時候,感覺裡面的程式碼會在0ms後立即運行。但不,JavaScript 就像是,「兄弟,我有自己的系統,等你了!」


JavaScript 的系統:事件循環

JavaScript 不僅僅直接運行程式碼,它還有一個名為 事件循環 的很酷的系統來處理任務。像這樣想:

  1. 主要任務(同步):

    像 console.log() 這樣的東西首先運行。這些都是直接的、面對面的任務。

  2. 微任務(Promise):

    接下來是承諾,甚至在計時器之前。就像他們有一張 VIP 票一樣。

  3. 任務佇列(計時器,如 setTimeout):

    計時器位於生產線的後面,僅在微任務完成後運行。即使你給它 0ms,它也會等待。


分解代碼

讓我們一步步看看發生了什麼事:

  1. 已建立承諾

    • console.log(1) 立即運行。
    • setTimeout(() => { ... }, 0) 被加到任務佇列
    • console.log(2) 立即運行。
  2. Promise .then():

    • .then() 回呼被加入到 微任務佇列
  3. console.log(4):

    • 直接執行,因為它是主腳本的一部分。
  4. 微任務運作(VIP)

    • promise 得到解決,因此 .then() 回調記錄「成功」。
  5. 任務佇列運行

    • setTimeout 回呼終於輪到了:記錄「timerStart」和「timerEnd」。

為什麼 0ms 不代表「現在」?

就算你說 0ms,setTimeout 也是總是延遲。不管怎樣,JavaScript 都會將其推送到任務佇列。在接觸任務佇列之前,系統會先清除所有同步任務和微任務(promise)。

所以,簡單來說:

0 毫秒與時間無關,而是與等待輪到有關。


像這樣想

想像一下您正在排隊等待過山車:

  1. 同步碼:購買快速通道票的人-他們是第一,毫無爭議。
  2. 承諾:持有 VIP 通行證的人——即使遲到,他們也是下一個排隊的人。
  3. 計時器(如 setTimeout):沒有通行證的普通人。即使你告訴他們“0毫秒等待”,他們仍然必須站在常規隊列中。

最終輸出回顧

以下是我們程式碼中的事件順序:

  1. console.log(1)(同步)
  2. console.log(2)(同步)
  3. console.log(4)(同步)
  4. 來自 .then() 的「成功」(微任務)
  5. console.log("timerStart")(任務隊列)
  6. console.log("timerEnd")(任務隊列)

為什麼這很重要?

了解 0ms 的真正工作原理可以幫助您編寫更好的非同步程式碼。當你的朋友調試 JavaScript 中的隨機延遲時,向他們解釋這也是一個很酷的技巧。

所以下次你看到 setTimeout(() => { ... }, 0) 時,請記住-這與時間無關,而是與時間有關。這是關於優先權

以上是setTimeout(..., ) 在 JavaScript 中的真正意義是什麼? (事件循環解釋!)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

在JavaScript中替換字符串字符 在JavaScript中替換字符串字符 Mar 11, 2025 am 12:07 AM

在JavaScript中替換字符串字符

自定義Google搜索API設置教程 自定義Google搜索API設置教程 Mar 04, 2025 am 01:06 AM

自定義Google搜索API設置教程

示例顏色json文件 示例顏色json文件 Mar 03, 2025 am 12:35 AM

示例顏色json文件

8令人驚嘆的jQuery頁面佈局插件 8令人驚嘆的jQuery頁面佈局插件 Mar 06, 2025 am 12:48 AM

8令人驚嘆的jQuery頁面佈局插件

10個jQuery語法熒光筆 10個jQuery語法熒光筆 Mar 02, 2025 am 12:32 AM

10個jQuery語法熒光筆

構建您自己的Ajax Web應用程序 構建您自己的Ajax Web應用程序 Mar 09, 2025 am 12:11 AM

構建您自己的Ajax Web應用程序

什麼是這個'在JavaScript? 什麼是這個'在JavaScript? Mar 04, 2025 am 01:15 AM

什麼是這個'在JavaScript?

10 JavaScript和JQuery MVC教程 10 JavaScript和JQuery MVC教程 Mar 02, 2025 am 01:16 AM

10 JavaScript和JQuery MVC教程

See all articles