您好,登錄后才能下訂單哦!
這篇文章主要講解了JavaScript中詞法作用域與作用域鏈的用法,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。
一、作用域
域表示的就是范圍,即作用域,就是一個名字在什么地方可以使用,什么時候不能使用。想了解更多關于作用域的問題推薦閱讀《你不知道的JavaScript上卷》第一章(或第一部分),從編譯原理的角度說明什么是作用域。概括的說作用域就是一套設計良好的規則來存儲變量,并且之后可以方便地找到這些變量。
在C、Java、C#等編程語言中,下面的語法報錯(偽代碼)
{ var num = 123; { console.log( num ); // num => 123 } } console.log( num ); //報錯
所謂的詞法(代碼)作用域,就是代碼在編寫過程中體現出來的作用范圍,代碼一旦寫好,不用執行,作用范圍就已經確定好了,這個就是所謂的詞法作用域。
在JS中詞法作用域的規則:
例子1:
var num = 123; function foo(){ console.log( num ); } foo(); //123
例子2:
if( false ){ var num = 123; } console.log( num ); //undefined
例子3:
var num = 123; function foo () { var num = 456; function func(){ console.log( num ); } func(); } foo(); //456
只有函數才能制造作用域結構,那么只要是代碼,至少有一個作用域,即全局作用域。
凡是代碼中有函數,那么這個函數就構成另一個作用域。如果函數中還有函數,那么在這個作用域中就又可以誕生一個作用域,那么將這樣的所有作用域列出來,可以有一個結構:函數內指向函數外的鏈式結構
例如:
function f1() { function f2() { } } var num = 456; function f3() { function f4() { } }
作用域鏈結構與DOM樹結構很相似.
步驟:
繪制如下程序的作用域鏈
function f1() { var num = 123; function f2() { console.log( num ); } f2(); } var num = 456; f1(); //123
函數f1 和變量 num=456, 在0級鏈,而f1下又可以展開1級鏈,1級鏈上有num=123和函數f2。程序f1()調用進入左邊1級鏈,而f1中又調用了f2函數,f2函數中console.log(num)
可以看作在2級鏈,此時,程序會向這一條鏈向上查找,首先2級鏈沒有num,向上到達1級鏈,剛好1級鏈上有num=123,所以就直接使用123,程序最后的結果就是打印123.
分析如下代碼:
var num = 123; function f1() { console.log( num ); } function f2(){ var num = 456; f1(); } f2(); //123
作用域鏈圖:
首先把num=123,函數f1,函數f2畫在0級鏈上。f1中只有一句console,畫出一條1級鏈,f2也下畫出1級鏈,鏈上有num=456和函數調用語句f1();
調用f2(),進入f2函數的作用域鏈,而在f2中又調用了f1函數,程序進入f1的作用域鏈,所以console.log(num)
會在此鏈上查找是否存在num,沒有,繼續向上一級鏈查找,剛好在0級鏈上找到了num=123,所以f1函數中的console.log(num)
就是123.
看完上述內容,是不是對JavaScript中詞法作用域與作用域鏈的用法有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。