這篇文章主要講解了JavaScript中詞法作用域與作用域鏈的用法,內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。
創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比鹽城網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式鹽城網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋鹽城地區(qū)。費(fèi)用合理售后完善,十年實(shí)體公司更值得信賴。
一、作用域
域表示的就是范圍,即作用域,就是一個(gè)名字在什么地方可以使用,什么時(shí)候不能使用。想了解更多關(guān)于作用域的問題推薦閱讀《你不知道的JavaScript上卷》第一章(或第一部分),從編譯原理的角度說明什么是作用域。概括的說作用域就是一套設(shè)計(jì)良好的規(guī)則來存儲(chǔ)變量,并且之后可以方便地找到這些變量。
在C、Java、C#等編程語言中,下面的語法報(bào)錯(cuò)(偽代碼)
{ var num = 123; { console.log( num ); // num => 123 } } console.log( num ); //報(bào)錯(cuò)
所謂的詞法(代碼)作用域,就是代碼在編寫過程中體現(xiàn)出來的作用范圍,代碼一旦寫好,不用執(zhí)行,作用范圍就已經(jīng)確定好了,這個(gè)就是所謂的詞法作用域。
在JS中詞法作用域的規(guī)則:
例子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
只有函數(shù)才能制造作用域結(jié)構(gòu),那么只要是代碼,至少有一個(gè)作用域,即全局作用域。
凡是代碼中有函數(shù),那么這個(gè)函數(shù)就構(gòu)成另一個(gè)作用域。如果函數(shù)中還有函數(shù),那么在這個(gè)作用域中就又可以誕生一個(gè)作用域,那么將這樣的所有作用域列出來,可以有一個(gè)結(jié)構(gòu):函數(shù)內(nèi)指向函數(shù)外的鏈?zhǔn)浇Y(jié)構(gòu)
例如:
function f1() { function f2() { } } var num = 456; function f3() { function f4() { } }
作用域鏈結(jié)構(gòu)與DOM樹結(jié)構(gòu)很相似.
步驟:
繪制如下程序的作用域鏈
function f1() { var num = 123; function f2() { console.log( num ); } f2(); } var num = 456; f1(); //123
函數(shù)f1 和變量 num=456, 在0級(jí)鏈,而f1下又可以展開1級(jí)鏈,1級(jí)鏈上有num=123和函數(shù)f2。程序f1()調(diào)用進(jìn)入左邊1級(jí)鏈,而f1中又調(diào)用了f2函數(shù),f2函數(shù)中console.log(num)
可以看作在2級(jí)鏈,此時(shí),程序會(huì)向這一條鏈向上查找,首先2級(jí)鏈沒有num,向上到達(dá)1級(jí)鏈,剛好1級(jí)鏈上有num=123,所以就直接使用123,程序最后的結(jié)果就是打印123.
分析如下代碼:
var num = 123; function f1() { console.log( num ); } function f2(){ var num = 456; f1(); } f2(); //123
作用域鏈圖:
首先把num=123,函數(shù)f1,函數(shù)f2畫在0級(jí)鏈上。f1中只有一句console,畫出一條1級(jí)鏈,f2也下畫出1級(jí)鏈,鏈上有num=456和函數(shù)調(diào)用語句f1();
調(diào)用f2(),進(jìn)入f2函數(shù)的作用域鏈,而在f2中又調(diào)用了f1函數(shù),程序進(jìn)入f1的作用域鏈,所以console.log(num)
會(huì)在此鏈上查找是否存在num,沒有,繼續(xù)向上一級(jí)鏈查找,剛好在0級(jí)鏈上找到了num=123,所以f1函數(shù)中的console.log(num)
就是123.
看完上述內(nèi)容,是不是對(duì)JavaScript中詞法作用域與作用域鏈的用法有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
本文名稱:JavaScript中詞法作用域與作用域鏈的用法
本文地址:http://aaarwkj.com/article22/isjecc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁設(shè)計(jì)公司、靜態(tài)網(wǎng)站、網(wǎng)站收錄、標(biāo)簽優(yōu)化、網(wǎng)站內(nèi)鏈、移動(dòng)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)