日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

JavaScript進(jìn)階(二)詞法作用域與作用域鏈實(shí)例分析

瀏覽:158日期:2023-10-29 11:31:11

本文實(shí)例講述了JavaScript詞法作用域與作用域鏈。分享給大家供大家參考,具體如下:

一、作用域

域表示的就是范圍,即作用域,就是一個(gè)名字在什么地方可以使用,什么時(shí)候不能使用。想了解更多關(guān)于作用域的問題推薦閱讀《你不知道的JavaScript上卷》第一章(或第一部分),從編譯原理的角度說明什么是作用域。概括的說作用域就是一套設(shè)計(jì)良好的規(guī)則來存儲(chǔ)變量,并且之后可以方便地找到這些變量。

1.1 塊級(jí)作用域

在C、Java、C#等編程語言中,下面的語法報(bào)錯(cuò)(偽代碼)

{ var num = 123; { console.log( num ); // num => 123 }}console.log( num ); //報(bào)錯(cuò)1.2 JS的詞法作用域

所謂的詞法(代碼)作用域,就是代碼在編寫過程中體現(xiàn)出來的作用范圍,代碼一旦寫好,不用執(zhí)行,作用范圍就已經(jīng)確定好了,這個(gè)就是所謂的詞法作用域。

在JS中詞法作用域的規(guī)則:

函數(shù)允許訪問函數(shù)外部的數(shù)據(jù) 整個(gè)代碼結(jié)構(gòu)中只有函數(shù)可以限定作用域 作用規(guī)則首先使用提升規(guī)則分析 如果當(dāng)前作用域中有了名字了,就不考慮外面的名字

例子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)很相似.

2.1 繪制作用域鏈

步驟:

看整個(gè)全局是一條鏈,即頂級(jí)鏈,記為0級(jí)鏈 看全局作用域中有什么成員聲明,就以方格的形式繪制到0級(jí)鏈上 再找函數(shù),只有函數(shù)可以限制作用域,因此從函數(shù)中引出新鏈,標(biāo)記為1級(jí)鏈 然后在每一個(gè)1級(jí)鏈中再次往復(fù)剛才的行為

JavaScript進(jìn)階(二)詞法作用域與作用域鏈實(shí)例分析

2.2 變量的訪問(搜索)規(guī)則 首先看變量在第幾條鏈上,在該鏈上看是否有變量的定義與賦值,如果有直接使用 如果沒有到上一級(jí)鏈上找( n - 1 級(jí)鏈),如果有直接使用,停止繼續(xù)查找。 如果還沒有在此往上找… 直到全局鏈(0級(jí)),還沒有就是is not defined 注意,切記:同級(jí)的鏈不可混合查找

繪制如下程序的作用域鏈

function f1() { var num = 123; function f2() { console.log( num ); } f2();}var num = 456;f1(); //123

JavaScript進(jìn)階(二)詞法作用域與作用域鏈實(shí)例分析

函數(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.

2.3 如何分析代碼 在分析代碼的時(shí)候切記從代碼的運(yùn)行角度上來分析,如果代碼給變量賦值了,一定要標(biāo)記到圖中 如果代碼比較復(fù)雜,可以在圖中表示代碼的內(nèi)容,有時(shí)候還要將原型圖與作用域圖結(jié)合起來分析

分析如下代碼:

var num = 123;function f1() { console.log( num );}function f2(){ var num = 456; f1();}f2(); //123

作用域鏈圖:

JavaScript進(jìn)階(二)詞法作用域與作用域鏈實(shí)例分析

首先把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.

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。

更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《JavaScript常用函數(shù)技巧匯總》、《javascript面向?qū)ο笕腴T教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

標(biāo)簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩1区2区日韩1区2区| 亚洲天堂一区二区| 日韩亚洲精品在线| 蜜桃成人av| 日韩欧美二区| 91精品国产乱码久久久久久久| 蜜臀国产一区| 成人羞羞视频播放网站| 久久精品导航| 在线国产一区| 麻豆精品91| 欧美精品九九| 视频一区视频二区中文字幕| 亚洲精品乱码日韩| 青青国产精品| 麻豆国产欧美日韩综合精品二区| 精品一区二区三区中文字幕| 国产一区二区三区久久 | 波多野结衣一区| 黄色成人精品网站| 久久不射中文字幕| 石原莉奈在线亚洲三区| 亚洲欧美成人综合| 亚洲精品伦理| 国产精品115| 中文字幕在线官网| 亚洲免费高清| 欧美一区久久| 精品女同一区二区三区在线观看| 日韩精品1区| 亚洲欧美综合| 欧美日韩亚洲三区| 美女福利一区二区三区| 国产一区二区高清| 国产探花一区在线观看| 精品免费视频| 欧美日韩视频| 91亚洲无吗| 国产精品久久久久久久久久10秀| 国产91一区| 综合亚洲视频| 国际精品欧美精品| 国产农村妇女精品一区二区| 91亚洲无吗| 在线日韩欧美| 日韩精品成人| 久久天堂精品| 日韩激情一区二区| 国产aⅴ精品一区二区四区| 正在播放日韩精品| 日韩高清电影免费| 国内精品福利| 99在线精品视频在线观看| 三级小说欧洲区亚洲区| 亚洲精品1区| 99国内精品| 国产欧美一区二区三区精品观看 | 亚洲激情av| 久久久国产精品网站| 亚洲精品电影| 美女视频黄 久久| 午夜电影亚洲| 欧美黄色精品| 久久福利一区| 国产成人免费精品| 91九色精品| 国产福利资源一区| 国产亚洲亚洲| 日韩中文在线电影| 日韩黄色av| 免费观看久久av| 麻豆久久久久久久| 亚洲精品乱码| 激情欧美国产欧美| 激情综合婷婷| 欧美日本二区| 影音先锋久久精品| 国产aⅴ精品一区二区三区久久| 中文视频一区| 亚洲成人精品| 久久中文字幕一区二区三区| 久久成人国产| 欧美肉体xxxx裸体137大胆| 国产情侣久久| 蜜桃视频一区二区三区在线观看| se01亚洲视频 | 精品国产精品久久一区免费式| 免费成人在线观看| 一区二区小说| 国内精品麻豆美女在线播放视频| 中文字幕日韩高清在线| 久久久久99| 国产一区二区视频在线看| 日韩在线网址| 国产女优一区| 国产中文一区| 91日韩欧美| 国产精品久久乐| 日韩精品导航| 蜜桃视频一区二区三区在线观看| 视频一区中文| 久久九九99| 久久影院午夜精品| 欧美激情视频一区二区三区免费| 男女精品网站| 亚洲精品中文字幕乱码| 久久精品观看| 日韩综合精品| 超碰超碰人人人人精品| 麻豆一区二区三| 国产精品二区影院| 国产欧美亚洲精品a| 欧美天堂一区| 日韩二区在线观看| 日韩不卡一二三区| 日韩美女精品| 日韩和欧美一区二区| 国产高清精品二区| 精品亚洲自拍| 日韩高清欧美| 一区二区亚洲精品| 色综合视频一区二区三区日韩 | 日韩欧美久久| 国产精品一国产精品k频道56| 美腿丝袜亚洲一区| 黄色在线网站噜噜噜| 精品一区免费| 亚洲毛片在线| 麻豆久久一区| 欧美美女一区| 日韩精品第二页| 精品一区二区三区免费看| 久久黄色影院| 美女精品网站| 国产精品一二| 国产91精品对白在线播放| 视频一区二区三区入口| 国产精品第十页| 日韩成人三级| 亚洲精品人人| 91日韩在线| 亚洲影视一区二区三区| 里番精品3d一二三区| 亚洲高清不卡| 欧美日韩18| 免费高潮视频95在线观看网站| 另类av一区二区| 久久精品国产99| 极品日韩av| 欧美永久精品| 久久精品青草| 欧美日韩99| 国户精品久久久久久久久久久不卡 | 国产精久久久| 久久精品国产亚洲夜色av网站 | 国产色99精品9i| 桃色一区二区| 日本成人在线视频网站| 偷拍精品精品一区二区三区| 亚洲精品综合| 日韩欧美1区| 国产一卡不卡| 欧美日韩黑人| 狠狠久久伊人中文字幕| 一级成人国产| 日韩中文在线播放| 91欧美精品| 国产国产精品| 精品国产黄a∨片高清在线| 免费观看在线色综合| av中文字幕在线观看第一页| 亚洲久久在线| 99久久亚洲精品| 日韩精品免费一区二区夜夜嗨 | 成人在线免费观看91| 蜜桃免费网站一区二区三区| 狂野欧美性猛交xxxx| 日韩中文字幕91| 日韩电影免费在线观看| 97久久超碰| 99久久久久国产精品| 国产午夜精品一区在线观看| 欧美sss在线视频| 欧美日本久久| 亚洲综合二区| 欧美日韩精品免费观看视欧美高清免费大片| 亚洲小说春色综合另类电影| 亚洲不卡系列| 久久精品资源| 青草久久视频| 美日韩精品视频| 成人va天堂| 97精品在线| 国产精品资源| 中文字幕一区二区三区在线视频| 日韩精品诱惑一区?区三区| 欧美国产日本| 国产欧美日韩影院| 视频一区中文字幕精品| 国产视频一区三区|