搜尋
首頁web前端js教程JavaScript 執行上下文 – JS 程式碼如何在幕後運行

在了解什麼是 JavaScript 執行上下文之前,我們需要知道如何以及在哪些環境中執行 JavaScript 程式碼。

首先,我們可以在兩種環境下執行JavaScript:

  1. 透過瀏覽器
  2. 透過 Node.js

JavaScript 程式碼如何在我們的電腦上運作?

當我們在電腦上編寫 JavaScript 程式碼然後嘗試執行它時,程式碼首先會轉到瀏覽器或 Node.js。

但是,我們寫的 JavaScript 程式碼並不能被瀏覽器或 Node.js 直接理解。此時,兩者都將程式碼傳送到內建的 JavaScript 引擎。有不同類型的引擎,例如:

  1. Google Chrome 中的 V8 引擎,
  2. Mozilla Firefox 中的SpiderMonkey,
  3. Node.js 中的 V8 引擎等

接下來,JavaScript 引擎將 JavaScript 程式碼編譯為機器碼。然後,該機器代碼被傳送到計算機,計算機執行它,我們會看到顯示的輸出。

身為程式設計師,我們需要很好地理解這個中間步驟,即 JavaScript 引擎如何將 JavaScript 程式碼編譯為機器碼。

所以,現在我們需要了解 JavaScript 引擎是如何運作的。 JavaScript 引擎以兩種方式將程式碼轉換為機器碼。第一個是解釋,第二個是編譯。那麼,什麼是解釋和編譯呢?

什麼是口譯,它是如何運作的?

解釋是逐行讀取所有用高階語言編寫的原始程式碼,並在讀取後立即將每一行轉換為機器碼的過程。如果在讀取一行程式碼時出現錯誤,則該過程會立即停止,使程式設計師可以輕鬆識別錯誤。這使得調試變得簡單。不過,由於這個過程是逐行讀取程式碼,所以速度相對較慢。

什麼是編譯,它是如何運作的?

編譯是將所有用高階語言寫的原始碼一次轉換為機器碼的過程。在這種情況下,即使程式碼中有錯誤,它仍然會編譯並且只在執行時顯示錯誤。結果,程式設計師更難識別錯誤,從而使偵錯變得更具挑戰性。然而,由於整個原始碼立即轉換為機器碼,因此這個過程相對更快。那麼現在問題來了:JavaScript 是編譯語言還是解譯型語言?

JavaScript 是編譯型語言還是解釋型語言?

最初,JavaScript 主要被認為是一種解釋性語言。然而,由於這個過程非常緩慢,現代 JavaScript 引擎開始使用一種結合解釋和編譯的新技術,稱為即時 (JIT) 編譯。這個過程結合了解釋和編譯,將程式碼轉換為機器碼。因此,與舊方法相比,它的調試速度更快、更容易。

要了解 JavaScript 的即時 (JIT) 編譯如何運作,我們需要了解 JavaScript 的執行上下文。現在讓我們試著了解 JavaScript 的執行上下文。

JavaScript 執行上下文

首先,看一下下面的程式碼範例。

程式碼範例

var a = 1;

function one() {
  console.log(a);

  function two() {
    console.log(b);

    var b = 2;

    function three(c) {
      console.log(a + b + c);
    }

    three(4);
  }

  two();
}

one();

輸出

1
undefined
7

當我們執行程式碼時,我們嘗試在two()函數內宣告b變數之前列印它,但輸出是未定義的。然而,沒有發生錯誤。問題出現了:b 變數的值是如何未定義的?答案就在 JavaScript 執行上下文。現在,我們將更詳細地探討 JavaScript 執行上下文。

JavaScript 中有兩種類型的執行上下文:

  1. 全域執行上下文
  2. 函數執行上下文

每個執行上下文都會經歷兩個階段:建立階段和執行階段。

全域執行上下文

當我們執行 JavaScript 程式碼時,首先發生的是全域執行上下文。這個上下文首先經歷它的創建階段,其中發生了幾件事:

創建階段

  1. 建立了一個全域物件。
  2. 建立此物件並為其指派全域物件的值。
  3. 創建了一個變數對象,其中聲明了所有函數和變數。變數被指派為未定義的值,函數被指派對其各自函數的參考。

建立階段完成後,全域執行上下文將進入下一個階段:執行階段,其中會發生更多步驟。

執行階段

  1. 在建立階段宣告並使用 undefined 初始化的變數現在被指派了各自的值。
  2. 在建立階段聲明的函數(儲存為引用)現在被呼叫並執行。

函數執行上下文

當全域執行上下文的執行階段所引用的函數被呼叫時,每個函數都會建立自己的函數執行上下文。就像全域執行上下文一樣,函數執行上下文也經歷創建階段,其中發生幾個步驟:

創建階段

  1. 為函數建立參數物件。
  2. 建立此物件並為其指派全域物件的值。
  3. 創建了一個變數對象,其中聲明了所有函數和變數。變數被指派為未定義的值,函數被指派對其各自函數的參考。

建立階段完成後,函數執行上下文將進入執行階段,其中會發生更多步驟。

執行階段

  1. 在創建階段聲明的變量,之前用 undefined 初始化,現在被分配了各自的值。
  2. 在建立階段宣告的函數現在被呼叫並執行。

巢狀函數中的函數執行上下文

當在其他函數中呼叫函數時,將為每個函數建立一個新的函數執行上下文。然後,每個函數執行上下文都會經歷創建階段和執行階段。對於在另一個函數內調用的每個函數,此過程都會繼續,並且每個函數將分別經歷這些階段。

我們看下圖。

JavaScript Execution Context – How JS Code Runs Behind the Scenes

我們已經看到全域執行上下文和函數執行上下文都會經歷一定的步驟。唯一的區別是,在全域執行上下文中,第一步是建立全域對象,而在函數執行上下文中,第一步是為函數建立參數對象。

現在,問題出現了:當為全域上下文和每個函數建立這些執行上下文時,JavaScript 如何管理這些執行上下文?

使用執行堆疊管理執行上下文

為了管理這些上下文,JavaScript 使用一種稱為執行堆疊的資料結構。執行堆疊以類似堆疊的方式儲存上下文:首先是全域執行上下文,然後是每個函數執行上下文。當所有執行上下文都儲存在堆疊中時,JavaScript 從堆疊頂部開始一一處理它們。

使用 let 和 const 來確定作用域

要注意的是,當我們在全域或函數作用域內使用 let 或 const 宣告變數時,這些變數在建立階段不會儲存在變數物件中,也不會使用 undefined 進行初始化。相反,這些變數是在執行階段直接聲明並賦值的。

考慮以下程式碼範例:

程式碼範例

var a = 1;

function one() {
  console.log(a);

  function two() {
    console.log(b);

    var b = 2;

    function three(c) {
      console.log(a + b + c);
    }

    three(4);
  }

  two();
}

one();

如果我們運行這段程式碼,我們將會遇到一個ReferenceError。這是因為我們試圖在宣告 b 變數之前列印它的值,並且由於 b 是使用 const 宣告的,因此它的行為與常規變數不同。使用 const 或 let 宣告的變數在建立階段不會儲存在變數物件中,這就是為什麼在為它們賦值之前嘗試存取它們時會出現錯誤。

結論

我希望對 JavaScript 如何運作以及其執行上下文階段發生的情況的解釋能讓您有更清晰的理解。在下一課中,我們將探討另一個 JavaScript 主題。

您可以在 GitHub 和 Linkedin 上與我聯絡。

以上是JavaScript 執行上下文 – JS 程式碼如何在幕後運行的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
在JavaScript中替換字符串字符在JavaScript中替換字符串字符Mar 11, 2025 am 12:07 AM

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

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

因此,在這裡,您準備好了解所有稱為Ajax的東西。但是,到底是什麼? AJAX一詞是指用於創建動態,交互式Web內容的一系列寬鬆的技術。 Ajax一詞,最初由Jesse J創造

如何創建和發布自己的JavaScript庫?如何創建和發布自己的JavaScript庫?Mar 18, 2025 pm 03:12 PM

文章討論了創建,發布和維護JavaScript庫,專注於計劃,開發,測試,文檔和促銷策略。

如何在瀏覽器中優化JavaScript代碼以進行性能?如何在瀏覽器中優化JavaScript代碼以進行性能?Mar 18, 2025 pm 03:14 PM

本文討論了在瀏覽器中優化JavaScript性能的策略,重點是減少執行時間並最大程度地減少對頁面負載速度的影響。

如何使用瀏覽器開發人員工具有效調試JavaScript代碼?如何使用瀏覽器開發人員工具有效調試JavaScript代碼?Mar 18, 2025 pm 03:16 PM

本文討論了使用瀏覽器開發人員工具的有效JavaScript調試,專注於設置斷點,使用控制台和分析性能。

jQuery矩陣效果jQuery矩陣效果Mar 10, 2025 am 12:52 AM

將矩陣電影特效帶入你的網頁!這是一個基於著名電影《黑客帝國》的酷炫jQuery插件。該插件模擬了電影中經典的綠色字符特效,只需選擇一張圖片,插件就會將其轉換為充滿數字字符的矩陣風格畫面。快來試試吧,非常有趣! 工作原理 插件將圖片加載到畫布上,讀取像素和顏色值: data = ctx.getImageData(x, y, settings.grainSize, settings.grainSize).data 插件巧妙地讀取圖片的矩形區域,並利用jQuery計算每個區域的平均顏色。然後,使用

如何構建簡單的jQuery滑塊如何構建簡單的jQuery滑塊Mar 11, 2025 am 12:19 AM

本文將引導您使用jQuery庫創建一個簡單的圖片輪播。我們將使用bxSlider庫,它基於jQuery構建,並提供許多配置選項來設置輪播。 如今,圖片輪播已成為網站必備功能——一圖胜千言! 決定使用圖片輪播後,下一個問題是如何創建它。首先,您需要收集高質量、高分辨率的圖片。 接下來,您需要使用HTML和一些JavaScript代碼來創建圖片輪播。網絡上有很多庫可以幫助您以不同的方式創建輪播。我們將使用開源的bxSlider庫。 bxSlider庫支持響應式設計,因此使用此庫構建的輪播可以適應任何

如何使用Angular上傳和下載CSV文件如何使用Angular上傳和下載CSV文件Mar 10, 2025 am 01:01 AM

數據集對於構建API模型和各種業務流程至關重要。這就是為什麼導入和導出CSV是經常需要的功能。在本教程中,您將學習如何在Angular中下載和導入CSV文件

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器