精品欧美一区二区三区在线观看 _久久久久国色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综合网| 国产激情一区二区三区| 欧美另类极品videosbestfree| www.色就是色.com| 色老头在线观看| 久久伊人蜜桃av一区二区| 国产精品自拍偷拍| 欧美国产精品一二三| 国产探花在线精品一区二区| 91精品国产入口| 日韩精品视频久久| 18av在线播放| 亚洲国产成人一区二区三区| 99高清视频有精品视频| 中国女人一级一次看片| 中文日韩欧美| 久久不射电影网| 国产一二三四五区| 欧美1区2区3区4区| 日韩一区二区三区在线| 国产主播中文字幕| 在线观看特色大片免费视频| 一区二区三区在线影院| 夜夜爽99久久国产综合精品女不卡| 少妇人妻偷人精品一区二区| 国内精品国产三级国产a久久| 日本精品久久中文字幕佐佐木| 欧美一区二区三区爽爽爽| 不卡视频在线| 精品视频久久久| 国产av一区二区三区传媒| 亚洲一区av| 在线免费不卡电影| 日本三级免费观看| 超碰成人av| 亚洲成人免费av| 免费的一级黄色片| 成人黄色在线电影| ...xxx性欧美| 性欧美18一19内谢| 亚洲欧美视频一区二区| 国产网站一区二区三区| 日韩动漫在线观看| 蜜桃免费在线| 国产午夜精品福利| 日韩精品伦理第一区| 福利成人在线观看| 日本一区二区综合亚洲| 亚洲精品一区二区毛豆| 国产美女性感在线观看懂色av| 久久婷婷久久一区二区三区| 欧美另类网站| 国产毛片在线| 中文字幕一区二区在线观看| 椎名由奈jux491在线播放 | 国产91精品一区二区麻豆亚洲| 成人看片人aa| 精品乱子伦一区二区| 国产精品香蕉一区二区三区| 97se亚洲综合在线| 黑人操亚洲女人| 成人手机电影网| 国产亚洲福利社区| 三级在线视频| 国产欧美视频在线观看| 一级二级三级欧美| 在线中文字幕电影| 香蕉加勒比综合久久| 黄色国产精品视频| 91精品国产66| 日韩一级片在线播放| 稀缺呦国内精品呦| 蜜桃国内精品久久久久软件9| 国产一区二区三区直播精品电影| 国产精品久久久久久成人| 婷婷激情综合| 久久久久久高潮国产精品视| 精品免费囯产一区二区三区| 日韩精品每日更新| 91久久精品美女高潮| 欧美亚洲精品在线观看| 久久久亚洲精品一区二区三区| 亚洲一二三区在线| 久久不射影院| 欧美亚洲国产bt| 三大队在线观看| 蜜乳av综合| 美女av一区二区三区| 天堂中文在线网| 精品一区二区三区不卡| 国产乱码精品一区二区三区卡| 国产私人尤物无码不卡| 亚洲综合色网站| 亚洲 中文字幕 日韩 无码| 精品久久国产一区| 亚洲欧美在线免费观看| 国产高潮国产高潮久久久91| 亚洲综合国产| 成人综合网网址| 性xxxx视频| 日韩美女视频一区二区| 精品中文字幕av| 国产一区二区视频在线看| 亚洲男人天堂手机在线| 青娱乐国产在线| 日韩高清不卡在线| www.成人av| 日本美女高清在线观看免费| 五月婷婷欧美视频| 深爱五月综合网| 精品久久成人| 91成人福利在线| av无码精品一区二区三区宅噜噜| 久久亚洲一级片| 美女av免费观看| 久久天堂影院| 亚洲精品网站在线播放gif| 欧美国产日韩在线观看成人| 日本视频在线一区| 美乳视频一区二区| 青春草视频在线观看| 欧美疯狂做受xxxx富婆| 成人性生交大片免费看无遮挡aⅴ| 亚洲理论在线| 成人资源av| 性直播体位视频在线观看| 欧美日韩精品一二三区| 亚洲无人区码一码二码三码的含义| 国内精品久久久久久久影视麻豆| 国产一区视频在线播放| 二区三区在线播放| 在线免费亚洲电影| 88久久精品无码一区二区毛片| 亚洲精选成人| 国产精品播放| 欧美aaa免费| 欧美大肚乱孕交hd孕妇| 看片网站在线观看| 国产精品一区久久久久| 男人日女人的bb| 伊人久久大香| 久久综合久久八八| 国产成人精品毛片| 一区二区在线观看视频 | 青草综合视频| 中文字幕一精品亚洲无线一区| 老熟妇仑乱一区二区av| 91麻豆福利精品推荐| 人妻精品无码一区二区三区 | 国产剧情在线观看一区二区| 青青草免费在线视频观看| 精品亚洲a∨一区二区三区18| 操日韩av在线电影| 国产99久久九九精品无码免费| 亚洲免费高清视频在线| 国产chinesehd精品露脸| 国产一区二区三区四区老人| 国产精品xxxx| 毛片免费看不卡网站| 国产一区二区三区视频在线观看| 午夜一区二区三区四区| 亚洲欧洲精品一区二区精品久久久 | 国产精品一级久久久| 欧美另类tv| 亚洲精品美女久久久久| 日韩电影在线观看一区二区| 国产女人18水真多18精品一级做| 在线观看免费污视频| 中文不卡在线| 国产伦精品一区| 欧美日韩成人影院| 久久九九国产精品怡红院| 国产av精国产传媒| 午夜日韩在线电影| 欧美日韩中文字幕视频| 国产一区二区三区免费在线观看| 成人一级生活片| 欧美调教视频| 国产美女精品免费电影| 永久免费网站在线| 精品亚洲一区二区三区在线播放| 国产成人精品一区二区色戒| 亚洲人成网站色在线观看| 欧美在线一级片| 天堂成人国产精品一区| 亚洲黄色网址在线观看| 欧美日韩另类图片| 成人激情视频在线观看| 超碰在线免费播放| 亚洲欧美中文日韩v在线观看| 国产精品高潮呻吟久久久| 天天av天天翘天天综合网色鬼国产 | 成人免费在线视频| 成人手机在线免费视频| 精品一区二区三区免费观看| 精品99在线视频| 亚洲有吗中文字幕| 欧日韩一区二区三区| 日韩免费成人| 国产精品第一视频| 国产福利在线免费观看| 色视频www在线播放国产成人| 手机看片一区二区| 4438x成人网最大色成网站| 亚洲伊人成人网| 亚洲精品综合在线| 中字幕一区二区三区乱码| 成人免费视频播放| 国产大片一区二区三区| 日日摸夜夜添夜夜添亚洲女人| 真人抽搐一进一出视频| 日韩在线不卡| 欧美日韩在线高清| 老牛精品亚洲成av人片| 亚洲最大的成人网| 国产精品亚洲成在人线| 奇米四色中文综合久久| 蜜臀av在线播放| 美日韩丰满少妇在线观看| www.在线播放| 亚洲欧洲视频在线| 天天色综合久久| 精品国产百合女同互慰| 国产ts变态重口人妖hd| 欧美精品三级日韩久久| 真实新婚偷拍xxxxx| 色综合久久久久久久久| 可以免费看的av毛片| 亚洲综合久久久| 久热这里有精品| 亚洲天堂a在线| chinese全程对白| 中文一区二区完整视频在线观看| 久久精品国产亚洲av久| 久久免费国产精品| 可以直接看的无码av| 99久久99久久免费精品蜜臀| 日本三级日本三级日本三级极| 国产成人日日夜夜| 一区二区三区人妻| 国产一区二区在线观看视频| 在线一区二区不卡| 精品综合久久久久久8888| 日韩中文字幕a| 极品美女销魂一区二区三区免费| 久久这里只精品| 久久国产三级精品| 亚洲精品乱码久久久久久动漫| 精品在线你懂的| 亚洲精品一二三四| 粉嫩13p一区二区三区| 在线观看免费视频黄| 91麻豆免费观看| 永久免费av无码网站性色av| 国产精品女上位| 日韩三级在线观看视频| 亚洲精品中文在线影院| 伊人国产在线观看| 欧美日韩亚洲视频| 国产在线观看第一页| 在线电影院国产精品| 亚洲av综合色区无码一区爱av| 精品久久久久久亚洲综合网 | 国产真人无遮挡作爱免费视频| 日本韩国欧美国产| 亚洲一级在线播放| 日韩欧美国产成人一区二区| 秋霞av鲁丝片一区二区| 日韩大陆欧美高清视频区| 三级在线播放| 久久精品成人动漫| 超碰在线最新网址| 国产a级全部精品| 国产精品一区三区在线观看| 国产嫩草一区二区三区在线观看| 蜜桃a∨噜噜一区二区三区| 在线免费观看成人| 狠狠爱www人成狠狠爱综合网| 国产视频一视频二| 麻豆传媒一区二区三区| 欧美丰满熟妇bbb久久久| 久久蜜桃香蕉精品一区二区三区| 男人天堂资源网| 午夜视频在线观看一区| 中文永久免费观看| 亚洲福利视频久久| 午夜视频在线观看网站| 欧美激情在线视频二区| 日韩成人影音| av在线亚洲男人的天堂| av亚洲免费| 人人妻人人澡人人爽欧美一区双| 日韩中文字幕麻豆| 永久av免费在线观看| 91丨国产丨九色丨pron| 97成人资源站| 91久久精品日日躁夜夜躁欧美| 99在线观看免费| 亚洲新声在线观看| 国产第一页在线| 91午夜在线播放| 欧美精美视频| 欧美又粗又长又爽做受| 蜜桃视频一区二区三区 | 日韩在线你懂的| 黄色a级在线观看| 日韩中文字幕亚洲一区二区va在线| 成人在线观看一区二区| 国产精品久99| 日本中文字幕久久| 亚洲第一国产精品| 黄a在线观看| 国产精品丝袜视频| 免费精品国产| 每日在线更新av| 成人sese在线| 免费一级肉体全黄毛片| 在线观看91精品国产麻豆| av在线播放网站| 青草青草久热精品视频在线网站| 香蕉成人app| 欧美日韩亚洲国产成人| 久久国产综合精品| 久久久久久久毛片| 欧美色欧美亚洲高清在线视频| 欧美综合视频在线| 久久久久久午夜| 一区二区三区免费在线看| 欧美另类videosbestsex日本| 久久精品国产99国产精品| 蜜臀久久99精品久久久久久| 色综合久久中文综合久久牛| 亚洲av片一区二区三区| 国模gogo一区二区大胆私拍 | 日韩在线视频免费播放| 欧美精品一区二区不卡 | 天天做天天爱综合| 亚洲综合20p| 亚洲欧美日韩久久精品| 国产精品呻吟久久| 成人97在线观看视频| 日韩三级不卡| 成人午夜免费在线| 不卡一二三区首页| 日韩激情在线播放| 日韩精品极品视频| 欧美性理论片在线观看片免费| 奇米视频888战线精品播放| 日韩在线观看一区二区| 黄色aaa视频| 欧美主播一区二区三区| 亚洲s色大片| 成人情趣片在线观看免费| 欧美在线日韩| 久久精品女同亚洲女同13| 欧美日韩免费观看中文| 国产女人在线观看| 成人免费xxxxx在线观看| 欧美日韩蜜桃| 成人免费无码大片a毛片| 日韩欧美在线视频免费观看| 国产精品秘入口| 91香蕉亚洲精品| 在线欧美亚洲| 亚洲激情视频小说| 欧美日韩国产不卡| 污视频在线免费观看网站| 国内精品久久久久久久果冻传媒| 男人的天堂成人在线| 中文字幕在线观看二区| 日韩欧美国产一区在线观看| av中文在线资源库| 色播亚洲视频在线观看| 国产乱子轮精品视频| 成人在线免费看视频| 日韩中文娱乐网| 中文一区二区三区四区| 日日摸天天爽天天爽视频| 亚洲欧洲成人av每日更新| 黄色av免费观看| 国产精品久久久久久超碰| 欧美日韩一区二区三区四区在线观看 | 国产亚洲欧美一区| 99热这里只有精品首页| 亚洲爆乳无码专区| 亚洲精品五月天| 黄色电影免费在线看| av成人观看| 蜜桃视频免费观看一区| 日韩xxx高潮hd| 日韩在线中文字| 色婷婷久久久| 波多野结衣免费观看| 91久久精品一区二区| 国产丝袜视频在线播放| 伊人久久青草| 91在线码无精品| 99在线无码精品入口|