搜尋
首頁web前端js教程JavaScript運作原理詳細分析解答

JavaScript運作原理詳細分析解答

May 18, 2018 pm 04:59 PM
javascriptjs分析

這篇文章給大家從理論詳細分析了JavaScript運作原理以及知識點分享,對此有興趣的學習下吧。

JavaScript是一種基於物件的動態、弱型別腳本語言(以下簡稱JS),是一種詮釋型語言,和其他的程式語言不同,如java/C 等編譯型語言,這些語言在程式碼執行前會進行通篇編譯,先編譯成字節碼(機器碼)。然後在執行。而JS不是這樣做的,JS是不需要編譯成中間碼,而是可以直接在瀏覽器中執行,JS運行過程可分為兩個階段,編譯和執行。 (可參考你不知道的JS這本書),當JS控制器轉到一段可執行的程式碼時(這段可執行程式碼就是編譯階段產生的),會創建與之對應的執行上下文(Excution Context簡稱EC)。執行上下文可以理解為執行環境(執行上下文只能由JS解釋器創建,也只能由JS解釋器使用,使用者是不可以操作該『物件』的)。

JS中的執行環境分為三類:

  • #全域環境:當JS引擎進入一個程式碼區塊時,如遇到<script>xxx</script>標籤,就是進入一個全域執行環境

  • 函數環境:當函數被呼叫時,在函數內部就形成了一個函數執行環境

  • eval():把字串單做JS程式碼執行,不建議使用

在一段JS程式碼中可能會產生多個執行上下文,在JS中用棧這種資料結構來管理執行上下文,棧的特徵是「先進後出,後進先出」,這種棧稱之為函數呼叫棧。

執行上下文的特點

  • 堆疊底永遠是全域執行上下文,有且僅有一個

  • 全域執行上下文只有在瀏覽器關閉時,才會彈出堆疊

  • 其他的執行上下文的數量沒有限制

  • 堆疊頂永遠是當前活動執行上下文,其餘的都處於等待狀態中,一旦執行完畢,立即彈出棧,然後控制權交回下一個執行上下文

  • 函數只有在每次被呼叫時,才會為其建立執行上下文,函數被宣告時是沒有的。

執行上下文可以形象的理解為一個普通的JS對象,一個執行上下文的生命週期大概包含兩個階段:

建立階段

#此階段主要完成三件事件,1、建立變數物件2、建立作用域鏈3、確定this指向

#執行階段

##此階段主要完成變數賦值、函數呼叫、其他操作

變數物件(VO)的建立過程

  • 1、根據函數參數,建立並初始化arguments對象,給予arguments物件加入屬性"0","1","2","3"等屬性,其初始值為undefined,並設定arguments.length值為實際傳入參數的個數。

  • 2、尋找function函數聲明,在變數物件上新增屬性,屬性名就是函數名,屬性值就是函數的參考值,如果已經存在同名的,則直接覆寫

  • 3、尋找var變數宣告(尋找變數時,會把函數的參數等價於var聲明,所以在VO中也會加入和參數名稱一樣的屬性,初始值也是undefined),在變數物件中加入屬性,屬性名就是變數名,屬性值是undefined,如果已經存在同名的,則不處理

如果存在同名識別碼(函數、變數),則函數可以覆蓋變量,函數的優先權高於變數

變數物件(OV)和激活物件(AO)是同一個東西,在不同時期的兩個叫法。在創建時期叫變數對象,在執行時期叫激活對象

以如下程式碼為例

#

var g_name="tom";
var g_age=20;
function g_fn(num){
 var l_name="kity";
 var l_age=18;
 function l_fn(){
  console.log(g_name + &#39;===&#39; + l_name + &#39;===&#39; + num);
 }
}
g_fn(10);

編譯階段

當JS控制器轉到這一段程式碼時,會建立一個執行上下文,G_EC


執行上下文的結構大概如下:

G_EC = {
 VO   : {},
 Scope_chain : [],
 this  : {}
}

/* VO的结构大概 */
VO = {
 g_name : undefined,
 g_age : undefined,
 g_fn : <函数在内存中引用值>
}

/* Scope_chain的大概结构如下 */
Scope_chain = [ G_EC.VO ] // 数组中第一个元素是当前执行上下文的VO,第二个是父执行上下文的VO,最后一个是全局执行上下文的VO,在执行阶段,会沿着这个作用域链一个一个的查找标识符,如果查到则返回,否知一直查找到全局执行上下文的VO

/* this */
this = undefined // 此时this的值是undefined

執行上下文一旦創建完畢,就立刻被壓入函數調用棧中,此時解釋器會悄悄的做一件事情,就是給當前VO中的函數添加一個內部屬性[[scope]],該屬性指向上面的作用域鏈。

g_fn.scope = [ global_EC.VO ] // 该scope属性只能被JS解释器所使用,用户无法使用

執行階段

一行一行執行程式碼,當遇到一個表達式時,就會去目前作用域鏈的中查找VO對象,如果找到則傳回,如果找不到,則繼續尋找下一個VO對象,直到全域VO對象終止。


此階段可以有變數賦值,函數調用等操作,當解釋器遇到g_fn()時,就知道這是一個函數調用,然後立即為其創建一個函數執行上下文,fn_EC ,該上下文fn_EC同樣有兩個階段


分別是建立階段和執行階段。


在建立階段,對於函數執行上下文,在建立變數物件時,會多建立一個arguments對象,然後為arguments物件新增屬性:"0","1", "2"其初始值為undefined,

  • 找function函數宣告

  • 找出var變數宣告

上面是我整理給大家的,希望今後對大家有幫助。

相關文章:

p5.js實作黃金螺旋動畫

JS中事件委託使用詳解

Vue.js裡computed與methods使用詳解

以上是JavaScript運作原理詳細分析解答的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
使用Next.js(後端集成)構建多租戶SaaS應用程序使用Next.js(後端集成)構建多租戶SaaS應用程序Apr 11, 2025 am 08:23 AM

我使用您的日常技術工具構建了功能性的多租戶SaaS應用程序(一個Edtech應用程序),您可以做同樣的事情。 首先,什麼是多租戶SaaS應用程序? 多租戶SaaS應用程序可讓您從唱歌中為多個客戶提供服務

如何使用Next.js(前端集成)構建多租戶SaaS應用程序如何使用Next.js(前端集成)構建多租戶SaaS應用程序Apr 11, 2025 am 08:22 AM

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

JavaScript:探索網絡語言的多功能性JavaScript:探索網絡語言的多功能性Apr 11, 2025 am 12:01 AM

JavaScript是現代Web開發的核心語言,因其多樣性和靈活性而廣泛應用。 1)前端開發:通過DOM操作和現代框架(如React、Vue.js、Angular)構建動態網頁和單頁面應用。 2)服務器端開發:Node.js利用非阻塞I/O模型處理高並發和實時應用。 3)移動和桌面應用開發:通過ReactNative和Electron實現跨平台開發,提高開發效率。

JavaScript的演變:當前的趨勢和未來前景JavaScript的演變:當前的趨勢和未來前景Apr 10, 2025 am 09:33 AM

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

神秘的JavaScript:它的作用以及為什麼重要神秘的JavaScript:它的作用以及為什麼重要Apr 09, 2025 am 12:07 AM

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

Python還是JavaScript更好?Python還是JavaScript更好?Apr 06, 2025 am 12:14 AM

Python更适合数据科学和机器学习,JavaScript更适合前端和全栈开发。1.Python以简洁语法和丰富库生态著称,适用于数据分析和Web开发。2.JavaScript是前端开发核心,Node.js支持服务器端编程,适用于全栈开发。

如何安裝JavaScript?如何安裝JavaScript?Apr 05, 2025 am 12:16 AM

JavaScript不需要安裝,因為它已內置於現代瀏覽器中。你只需文本編輯器和瀏覽器即可開始使用。 1)在瀏覽器環境中,通過標籤嵌入HTML文件中運行。 2)在Node.js環境中,下載並安裝Node.js後,通過命令行運行JavaScript文件。

在Quartz中如何在任務開始前發送通知?在Quartz中如何在任務開始前發送通知?Apr 04, 2025 pm 09:24 PM

如何在Quartz中提前發送任務通知在使用Quartz定時器進行任務調度時,任務的執行時間是由cron表達式設定的。現�...

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尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

記事本++7.3.1

記事本++7.3.1

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