精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

什么是JavaScript的作用域

開發(fā) 前端
現(xiàn)代編程語言的最基本功能之一就是能夠存儲(chǔ)變量當(dāng)中的值,以便于之后的使用于修改。也正是這個(gè)功能將狀態(tài)帶給了程序。在JavaScript中,作用域就是一套設(shè)計(jì)良好的規(guī)則來存儲(chǔ)變量。

 作用域的概念

現(xiàn)代編程語言的最基本功能之一就是能夠存儲(chǔ)變量當(dāng)中的值,以便于之后的使用于修改。也正是這個(gè)功能將狀態(tài)帶給了程序。

在JavaScript中,作用域就是一套設(shè)計(jì)良好的規(guī)則來存儲(chǔ)變量。

簡(jiǎn)述編譯原理

通常我們會(huì)將JavaScript歸類為“動(dòng)態(tài)”或“解釋執(zhí)行“語言,但它實(shí)際上是一門編譯語言。與傳統(tǒng)的編譯語言不同,它不是提前編譯的,編譯結(jié)果也不能在分布式系統(tǒng)中進(jìn)行移植。

例如V8引擎,為了提高JavaScript代碼的運(yùn)行性能,在運(yùn)行之前會(huì)先將其編譯為本地的機(jī)器碼,然后再去執(zhí)行機(jī)器碼,達(dá)到提升速度的目的。

  •  分詞/詞法分析

           這個(gè)過程將由字符組成的代碼分解成對(duì)程序有意義的代碼塊,這些代碼塊被稱為詞法單元。

    例如 var foo = 'bar' 通常會(huì)被分解為這些詞法單元:var 、 foo 、 = 、 'bar'

  •  解析/語法分析

           這個(gè)過程將詞法單元轉(zhuǎn)換成一個(gè)“由元素逐級(jí)嵌套組成的代表程序語法的樹“,這個(gè)樹被稱為“抽象語法樹”(AST)。    

    image

  •  代碼生成

          將上邊的抽象語法樹轉(zhuǎn)換為機(jī)器可執(zhí)行代碼

JavaScript引擎比只有三個(gè)步驟的語言的編譯器要復(fù)雜的多。例如在語法分析和代碼生成階段有特定的步驟來對(duì)運(yùn)行性能進(jìn)行優(yōu)化,包括對(duì)冗余元素進(jìn)行優(yōu)化等。

對(duì)于JavaScript來說,大部分情況下編譯發(fā)生在代碼執(zhí)行的前幾微秒,任何代碼片段在執(zhí)行前都要進(jìn)行編譯。因此JavaScript編譯器首先對(duì) var foo = 'bar' 進(jìn)行編譯,然后做好執(zhí)行它的準(zhǔn)備,并且通常馬上就會(huì)執(zhí)行它。

引擎、編譯器、作用域在賦值操作中的配合

  •  引擎:從頭到尾負(fù)責(zé)整個(gè)JavaScript程序編譯及執(zhí)行過程
  •  編譯器:負(fù)責(zé)語法分析及代碼生成
  •  作用域:負(fù)責(zé)收集維護(hù)由所有變量組成的一系列查詢

對(duì)于 var foo = 'bar' 這段代碼,大家很有可能認(rèn)為是一句簡(jiǎn)單的聲明。而事實(shí)上JavaScript執(zhí)行時(shí)會(huì)將它分成兩個(gè)完全不同的聲明。

  1.  編譯器首先將這段代碼分解成詞法單元,然后解析為樹結(jié)構(gòu)。(在下一步代碼生成時(shí),處理這段代碼的方式會(huì)跟預(yù)期有所不同)
  2.  遇到 var foo ,編譯器會(huì)檢查作用域是否已有同名變量存在。如果有的話編譯器會(huì)忽略聲明,繼續(xù)編譯。否則它會(huì)生成代碼在當(dāng)前作用域的變量集合中聲明一個(gè)新的變量,命名為 foo
  3.  接下來編譯器會(huì)為引擎生成運(yùn)行時(shí)所需代碼,用來處理 foo = 'bar' 這個(gè)賦值操作。
  4.  引擎運(yùn)行時(shí)會(huì)首先查詢當(dāng)前作用域是否存在叫做 foo 的變量。如果有引擎則會(huì)使用這個(gè)變量,否則會(huì)一直向上層作用域查找。
  5.  如果最終找到了 foo 這個(gè)變量,就會(huì)將 'bar' 賦給它,否則拋出異常。

總結(jié):變量的賦值會(huì)執(zhí)行兩個(gè)動(dòng)作:首先是編譯器在當(dāng)前作用域中聲明變量(如果變量未被聲明過);接著運(yùn)行時(shí)引擎在作用域查找該變量,能找到就會(huì)對(duì)它賦值。

LHS查詢 vs RHS查詢

引擎執(zhí)行編譯器生成的代碼時(shí),會(huì)通過查找 foo 來判斷是否已經(jīng)聲明過。查找的過程由作用域來協(xié)助。在我們的例子中,引擎為變量 foo 進(jìn)行的時(shí)LHS查詢,還有另一個(gè)查找類型叫RHS查詢。顧名思義,它們的意思是Left hand side 和 Right hand side

  •  LHS:變量出現(xiàn)在賦值操作的左側(cè)(查找賦值操作的目標(biāo)是誰)
  •  RHS:變量在其他位置出現(xiàn)(查找值的源頭) 
  1. // 考慮下邊的代碼  
  2. console.log(foo) 

此例中 foo 的引用就是RHS查詢,這里沒有賦予 foo 任何值,相反的,我們需要查找 foo 的值,才能傳遞給log方法。 

  1. // 相比之下  
  2. foo = 'bar' 

這里對(duì) foo 的查詢則是LHS查詢,我們并不關(guān)心 foo 當(dāng)前的值是什么, 只是想為這個(gè)賦值操作找到目標(biāo)。 

  1. // 再分析下邊的代碼  
  2. function foo(a) {  
  3.   console.log(a)  
  4.  
  5. foo('bar') 

這段代碼里既有LHS查詢又有RHS查詢

  1.  最后一行 foo(...) 函數(shù)的調(diào)用需要對(duì) foo 進(jìn)行RHS查詢 → 找到 foo 的值
  2.  入?yún)r(shí)存在隱式的 a = 'bar' ,需要對(duì) a 進(jìn)行LHS查詢
  3.  console.log(a) 對(duì) a 進(jìn)行RHS查詢
  4.  console.log(...) 本身也需要對(duì) console 對(duì)象進(jìn)行RHS查詢

作用域的嵌套

我們?cè)谖恼麻_始時(shí)說過,作用域是根據(jù)名稱查找變量的一套規(guī)則。實(shí)際情況中需要同時(shí)顧及幾個(gè)作用域。

當(dāng)一個(gè)塊或函數(shù)嵌套在另一個(gè)塊或函數(shù)中時(shí),就發(fā)生了作用域的嵌套。因此在當(dāng)前作用域中沒有查找到目標(biāo)變量時(shí),會(huì)逐層向上查找直到全局作用域。 

  1. // 考慮以下代碼  
  2. function foo(a) { 
  3.  console.log(a + b)  
  4.  
  5. var b = 258 
  6. foo(369) 

對(duì) b 進(jìn)行的RHS查詢無法在 foo 內(nèi)部完成,但可以在上一級(jí)的作用域中完成(在此例中是全局作用域)。

LHS,RHS查詢都會(huì)在作用域內(nèi)逐層查找,直到找到為止(或到達(dá)全局作用域)。

ReferenceError

上一節(jié)提到了LHS,RHS都會(huì)在作用域內(nèi)逐層查找變量,但如果到達(dá)全局作用域仍然沒有找到變量怎么辦呢?

這時(shí)區(qū)分LHS和RHS查詢的意義就體現(xiàn)出來了。

如果RHS查詢?cè)谒星短椎淖饔糜蛑卸紱]有找到所需變量,引擎就會(huì)拋出 ReferenceError。

如果LHS查詢?cè)谒星短椎淖饔糜蛑卸紱]有找到所需變量,引擎就會(huì)在全局作用域中創(chuàng)建一個(gè)具有該名稱的變量,并將其返回給引擎。

注意:ES5中引入了嚴(yán)格模式,與普通模式相比,嚴(yán)格模式其中一個(gè)不同就是進(jìn)制自動(dòng)或隱式的創(chuàng)建全局變量。因此在嚴(yán)格模式下LHS查詢失敗時(shí)不會(huì)創(chuàng)建并返回全局變量,引擎同樣會(huì)拋出 ReferenceError。

總結(jié)

  •  作用域是一套規(guī)則,用于確定在何處以及如何查找變量。如果查找的目的是對(duì)變量賦值,會(huì)使用LHS查詢;如果目的是獲取變量的值,會(huì)使用RHS查詢。
  •  JavaScript引擎會(huì)在代碼執(zhí)行前對(duì)其進(jìn)行編譯。在這個(gè)過程中,像 var foo = 'bar' 這種聲明會(huì)被分解成兩個(gè)獨(dú)立的步驟。

            1.  var foo 在其作用域中聲明新的變量。此操作在代碼執(zhí)行前進(jìn)行。

            2.  接下來 foo = 'bar' 會(huì)查詢(LHS)變量 foo 并對(duì)其賦值。

  •  LHS和RHS查詢都會(huì)在當(dāng)前執(zhí)行作用域中開始,如果有需要(沒有在當(dāng)前作用域找到變量)就會(huì)向上級(jí)作用域繼續(xù)查找目標(biāo)變量,一直抵達(dá)全局作用域,無論找到與否都會(huì)停止。
  •  不成功的RHS查找會(huì)導(dǎo)致拋出 ReferenceError ,不成功的LHS查找會(huì)導(dǎo)致自動(dòng)隱式地創(chuàng)建一個(gè)全局變量(非嚴(yán)格模式下),或者拋出 ReferenceError(嚴(yán)格模式下)。 

 

責(zé)任編輯:龐桂玉 來源: 前端大全
相關(guān)推薦

2011-09-06 09:56:24

JavaScript

2019-03-13 08:00:00

JavaScript作用域前端

2011-04-18 09:31:35

JavaScript

2017-09-14 13:55:57

JavaScript

2013-09-05 10:07:34

javaScript變量

2015-07-21 13:39:58

Javascript作用域

2011-05-12 18:26:08

Javascript作用域

2016-12-19 11:10:32

JavaScript變量作用域

2021-12-06 07:15:48

Javascript作用域閉包

2015-07-03 11:23:51

JavaScript作用域聲明提前

2021-07-01 11:56:51

JavaScript開發(fā)代碼

2020-12-16 11:09:27

JavaScript語言開發(fā)

2015-10-20 13:11:23

JavascriptHoisting

2021-11-28 15:15:13

軟件測(cè)試域測(cè)試開發(fā)

2010-09-29 15:02:23

DHCP作用域

2021-05-25 10:15:20

JavaScript 前端作用域

2009-03-16 09:39:01

函數(shù)詞法作用域Javascript

2021-03-17 08:39:24

作用域作用域鏈JavaScript

2021-03-09 08:35:51

JSS作用域前端

2021-03-16 22:25:06

作用域鏈作用域JavaScript
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

久久不见久久见中文字幕免费| 天堂av电影在线观看| 欧美码中文字幕在线| 奇米色一区二区三区四区| 制服丝袜日韩国产| 精品国产乱码久久久久久88av | 国产女人18毛片水真多成人如厕| 欧美成人h版在线观看| 四川一级毛毛片| 高清在线视频不卡| 久久久久久电影| 国产在线拍偷自揄拍精品| 国产中文字字幕乱码无限| 日本成人7777| 91精品一区二区三区在线观看| 欧美午夜小视频| av电影在线观看| 国产乱人伦偷精品视频不卡| 国产不卡一区二区在线播放| av激情在线观看| 午夜av不卡| 国产精品毛片久久久久久| 成人动漫在线视频| 亚洲高清视频免费观看| 精品福利电影| 日韩中文字幕第一页| yy1111111| 成人亚洲精品| 欧美伊人精品成人久久综合97| 999一区二区三区| 日本最新在线视频| 2021国产精品久久精品| 不卡的av一区| 一区二区三区免费在线| 久久在线91| 欧美激情欧美激情| 日本一二三不卡视频| 欧美理伦片在线播放| 日韩情涩欧美日韩视频| 在线免费视频一区| 卡通欧美亚洲| 欧美日韩在线影院| 欧美精品久久久久久久自慰| 黄色精品在线观看| 国产亲近乱来精品视频 | 中文字幕亚洲影视| 亚洲愉拍自拍另类高清精品| 亚洲精品一品区二品区三品区 | 中文字幕久精品免费视频| 美女又爽又黄免费| 精品自拍偷拍| 亚洲国产日韩精品在线| 日本天堂在线播放| 97久久综合区小说区图片区| 日韩欧美二区三区| 91蝌蚪视频在线| 女同一区二区免费aⅴ| 国产精品成人免费精品自在线观看| 欧美一进一出视频| 瑟瑟在线观看| 久久午夜色播影院免费高清| 黄色99视频| 天天操天天射天天| 性欧美精品高清| 中文字幕日本精品| 午夜黄色福利视频| 视频在线观看免费影院欧美meiju| 亚洲国产cao| 无码熟妇人妻av在线电影| 日本精品专区| 久久久99免费| 性欧美videosex高清少妇| 天堂中文8资源在线8| 亚洲欧美福利一区二区| 日本福利视频网站| av中文字幕在线看| 日韩欧美成人区| 91香蕉视频污版| 亚洲国产精选| 日韩精品在线一区二区| 中文字幕a在线观看| 西野翔中文久久精品字幕| 亚洲欧美精品一区二区| 亚洲综合欧美综合| jizz性欧美23| 日韩精品福利网站| xxxx在线免费观看| 俺来也官网欧美久久精品| 亚洲午夜激情av| 成人在线看视频| 欧美一级做一级爱a做片性| 欧美一区二区三区婷婷月色| 毛茸茸free性熟hd| 欧美码中文字幕在线| 欧美巨乳美女视频| 国产成人免费观看视频| 奇米精品一区二区三区四区 | 麻豆一区二区| 在线播放国产一区二区三区| 日韩一级片大全| 亚洲国产国产亚洲一二三| 国产99久久精品一区二区 夜夜躁日日躁| 一区二区视频免费| 成人深夜视频在线观看| 小说区图片区图片区另类灬| 国产美女情趣调教h一区二区| 色系网站成人免费| 9191在线视频| 视频一区中文| 欧美精品xxx| 国产一区二区三区四区视频| 26uuu亚洲综合色| 国产美女视频免费| 老司机成人影院| 欧美tickling网站挠脚心| 卡一卡二卡三在线观看| 亚洲高清电影| 91久久久久久久| 国产视频第一页在线观看| 亚洲在线视频网站| 色婷婷成人在线| 亚欧洲精品视频在线观看| 欧美成在线观看| 中文字幕一区二区久久人妻| 99国内精品久久| 视色,视色影院,视色影库,视色网| 老司机2019福利精品视频导航| 日韩欧美国产综合| 日本午夜精品视频| 性感少妇一区| 国产乱码一区| 色呦呦网站在线观看| 欧美日韩一区在线观看| 中国美女乱淫免费看视频| 狠狠入ady亚洲精品| 亚洲va欧美va国产综合久久| 中文在线a天堂| 波多野结衣在线一区| 91免费视频黄| 欧美少妇激情| 这里只有精品久久| 久久影视中文字幕| 久久久久亚洲综合| 欧美日韩激情视频在线观看| 成人爽a毛片| 欧美黑人性猛交| 精品国产九九九| 最新不卡av在线| 亚洲激情在线看| 国产成人久久精品一区二区三区| 亚洲网址你懂得| 国产精品夜夜夜爽阿娇| 99精品在线观看| 国产精品激情av电影在线观看| 亚州av在线播放| 婷婷国产v国产偷v亚洲高清| 亚洲人辣妹窥探嘘嘘| 久草精品在线| 欧美中文在线观看| 每日更新av在线播放| 日韩欧美在线第一页| 瑟瑟视频在线观看| 久久婷婷一区| 色综合久久88色综合天天提莫| 日韩中文在线播放| 视频直播国产精品| 国产精品视频a| 99久久伊人精品| 四虎一区二区| 日韩国产91| 另类少妇人与禽zozz0性伦| 国产美女三级无套内谢| 亚洲欧美日韩中文播放| 18深夜在线观看免费视频| 国产一在线精品一区在线观看| 国产成人女人毛片视频在线| a级片免费在线观看| 亚洲欧美一区二区三区在线| 激情网站在线观看| 国产精品女同一区二区三区| 爽爽爽在线观看| 狠久久av成人天堂| 久久久久久九九| 韩国成人在线| 欧美成人在线免费视频| 免费观看黄色av| 一本一道久久a久久精品| 一二三四在线观看视频| 国产成人综合亚洲网站| 欧美牲交a欧美牲交| 国产亚洲一卡2卡3卡4卡新区| 久久精品国产一区二区电影| 精品国产无码一区二区三区| 欧美日韩美女视频| 久久日免费视频| 国产高清亚洲一区| 欧美污视频网站| 久久久久久久久久久久久久久久久久 | 人妻 日韩 欧美 综合 制服| 久久精品动漫| 五月天在线免费视频| 欧美日韩破处| 成人妇女免费播放久久久| 国语对白在线刺激| 亚洲欧美在线一区二区| 国产精品日韩无码| 色综合婷婷久久| 国产盗摄x88av| 久久精品视频一区二区三区| 在线免费看v片| 亚洲专区一区二区三区| 欧美三级午夜理伦三级老人| 国产影视精品一区二区三区| 成人黄色片视频网站| 在线观看精品| 欧美精品成人91久久久久久久| 九色视频在线播放| 精品动漫一区二区三区在线观看| 亚洲一区二区色| 欧美日韩中文在线| 久久久.www| 久久99精品久久久久久动态图| 国产 日韩 亚洲 欧美| 日本在线电影一区二区三区| 精品国产乱码一区二区三区四区| 91国产精品| 国产精品电影网站| 激情aⅴ欧美一区二区欲海潮| 久久视频免费观看| 91在线看片| 亚洲人成亚洲人成在线观看| 少妇高潮一区二区三区69| 欧美一区二区三区视频免费 | 91精品国产91久久久久久一区二区 | 欧美成熟视频| 一级一片免费播放| 欧美日韩激情| 欧美日韩亚洲一区二区三区在线观看| 国产精品毛片视频| 不卡视频一区二区| 亚洲精品在线a| 5566中文字幕一区二区| 国产精品久久久久久av公交车| 91精品国产自产在线| 成人性片免费| 国产精品久久久久久久久久新婚| 波多野结衣亚洲一二三| 欧美一区二三区| 成人直播视频| 日韩美女在线看| 国精产品一区二区三区有限公司| 国产成人精品久久久| 日韩欧美精品电影| 国产精品99久久久久久人| 成人va天堂| 国产精品美女呻吟| 久久女人天堂| 91久久国产精品91久久性色| 国产精品3区| 成人国产1314www色视频| 哺乳挤奶一区二区三区免费看| 国产精品嫩草在线观看| 九色丨蝌蚪丨成人| 久久国产精品一区二区三区四区 | 亚洲欧美日韩成人| 黄色在线观看网| 俺去了亚洲欧美日韩| a黄色片在线观看| 亚洲国产精品va在线看黑人动漫| 国产成人三级在线观看视频| 亚洲成avwww人| 深夜福利视频一区| 一区二区三区久久精品| 日本在线人成| 久久久久久九九九| 英国三级经典在线观看| 国产精品白嫩美女在线观看| 亚洲午夜国产成人| 高清国产在线一区| 视频小说一区二区| 日韩精品欧美专区| 亚洲国产精品久久久天堂 | 成人黄色在线免费观看| 精品国产一区二区三区不卡蜜臂| 欧美大香线蕉线伊人久久| 欧美天天综合| 亚洲精品国产suv一区88| 在线亚洲欧美| 亚洲18在线看污www麻豆| 成人视屏免费看| 国产第一页精品| 亚洲一区二区黄色| 亚洲熟妇无码乱子av电影| 一区二区三区美女| 亚洲黄色一区二区| 欧美裸体一区二区三区| 亚洲黄色小说网址| 欧美放荡的少妇| 日本免费不卡视频| 日韩中文字幕国产精品| 国产无遮挡裸体视频在线观看| 国产精品久久久久久久久免费看 | 美日韩免费视频| 亚洲精品久久| 国产精品69页| 国产999精品久久| 国产精品无码无卡无需播放器| 亚洲激情在线播放| 波多野结衣高清视频| 精品国产髙清在线看国产毛片| av中文在线| 91av网站在线播放| 欧美一区一区| 色综合影院在线观看| 亚洲精品裸体| 欧美精品 - 色网| 国产性做久久久久久| 国产系列精品av| 91精品国产综合久久久久久久久久| 亚欧洲精品视频| 久久久久久久爱| avtt久久| 亚洲精品免费在线看| 午夜在线一区二区| 久久久久国产免费| 日韩毛片一二三区| 亚洲av人无码激艳猛片服务器| 亚洲国产精彩中文乱码av| 亚洲羞羞网站| 91久久精品美女| 99久久精品网| 97公开免费视频| 91色porny蝌蚪| 中日韩黄色大片| 色哟哟一区二区三区| 亚洲精品久久久蜜桃动漫| 久久久久www| 91丨精品丨国产| 亚洲日本精品| 日产国产欧美视频一区精品| 成人免费看aa片| 一本大道久久a久久精二百| 五月婷婷在线播放| 97在线视频免费看| 91在线一区| 99er在线视频| 高清成人免费视频| 九九免费精品视频| 日韩美女视频一区二区在线观看| 在线三级电影| 91成品人片a无限观看| 卡一精品卡二卡三网站乱码 | 久久福利毛片| 中文字幕一区二区三区人妻| 色综合久久久久综合体桃花网| 日韩精品系列| 国产91在线播放九色快色| 美女毛片一区二区三区四区| 欧美综合在线观看视频| 久久久久久久久伊人| 黄色在线免费观看| 亚洲人成电影网站色www| 欧美gay视频| 亚洲ai欧洲av| 国产真实乱对白精彩久久| 欧美卡一卡二卡三| 亚洲成年人在线播放| 日本а中文在线天堂| 欧美精品在线一区| 奇米精品一区二区三区四区| 老司机成人免费视频| 精品免费日韩av| 国产美女高潮在线观看| 日本在线高清视频一区| 久久成人免费电影| 九九精品在线观看视频| 日韩成人在线视频| 日本另类视频| 伊人再见免费在线观看高清版| 成人激情校园春色| 中文在线第一页| 日韩在线免费观看视频| 天堂va在线高清一区| 女人喷潮完整视频| 国产精品久久久久久亚洲毛片| 99热这里只有精品在线| 91国产中文字幕| 区一区二视频| 免费看91视频| 日本高清免费不卡视频| a视频在线观看| 欧美日韩精品久久| 国产福利一区二区三区在线视频| 97久久久久久久| zzijzzij亚洲日本成熟少妇| 日韩最新在线| 青青草精品在线| 欧美中文字幕亚洲一区二区va在线| 天堂av在线电影| 亚洲午夜在线观看|