作用域(一)

這段時(shí)間小編把兩本js的經(jīng)典圖書(shū)看完了,一本是《深入理解JavaScript》,一本是《你不知道的JavaScript》让网。中間有些內(nèi)容小編是根本沒(méi)看懂,這次小編決定看第二遍并和大家一起分享書(shū)中的內(nèi)容,期待著和大家一起進(jìn)步事期。大家還可以關(guān)注我的微信公眾號(hào),蝸牛全棧纸颜。
一兽泣、RHS和LHS先看一個(gè)js中很常用的賦值語(yǔ)句

var a = 2;

在這個(gè)例子中,js的引擎會(huì)對(duì)變量a進(jìn)行LHS查詢胁孙,當(dāng)然了唠倦,和這個(gè)相對(duì)應(yīng)的是RHS查詢称鳞。那究竟什么是LHS和RHS呢,簡(jiǎn)單一點(diǎn)說(shuō)稠鼻,如果是對(duì)某個(gè)變量進(jìn)行賦值冈止,就是進(jìn)行了一次LHS。獲取一個(gè)變量的值候齿,就進(jìn)行了一次RHS熙暴。說(shuō)的更準(zhǔn)確一點(diǎn),RHS查詢就是超著某個(gè)變量的值慌盯。而LHS查詢則是試圖找到變量的容器本身周霉,然后對(duì)其賦值。

考慮以下代碼:

console.log(a);

這段代碼是對(duì)a的RHS引用亚皂,因?yàn)檫@里只是查詢并取得a的值诗眨,并沒(méi)有給a賦值。然后將取得的值傳遞給console.log相比之后孕讳,下面這段代碼就是對(duì)a的LHS引用匠楚,因?yàn)槲覀儾⒉魂P(guān)心當(dāng)前的a的值是什么,只是把2賦值給變量a

var a = 2;

了解了RHS和LHS厂财,我們來(lái)看一個(gè)相對(duì)復(fù)雜的例子芋簿。

function foo(a){
    console.log(a) // RHS
}

foo(2). //LHS

二、作用域嵌套

我們知道璃饱,作用域是根據(jù)名稱查找變量的一套規(guī)則与斤。但在實(shí)際情況中,通常需要同時(shí)估計(jì)幾個(gè)作用域荚恶。當(dāng)一個(gè)塊或函數(shù)嵌套在另一個(gè)塊或函數(shù)中的時(shí)候撩穿,就發(fā)生了作用域的嵌套。因此谒撼,在當(dāng)前作用域中無(wú)法找到某個(gè)變量時(shí)食寡,引擎就會(huì)在改作用域的外層嵌套作用域繼續(xù)查找,直到找到改變量廓潜,或抵達(dá)最外層的作用域(全局作用域)為止抵皱。考慮以下代碼

fuction foo(a){
  console.log(a + b);
}
var b = 3;
foo(2); // 5

在這段代碼中辩蛋,對(duì)于函數(shù)foo呻畸,只接收一個(gè)參數(shù)a,對(duì)于變量b悼院,在該函數(shù)作用域內(nèi)并沒(méi)有找到定義伤为,于是引擎就會(huì)在外層作用域繼續(xù)尋找,剛好据途,在全局作用域下绞愚,找到了var b = 3;然后將兩個(gè)數(shù)字相加之后輸出叙甸。為了更形象,可以把作用域想象成一個(gè)高大的建筑

image.png

LHS和RHS引用都會(huì)在當(dāng)前樓層進(jìn)行查找爽醋,如果沒(méi)有找到蚁署,就會(huì)坐電梯前往上一層樓,如果還是沒(méi)有找到就繼續(xù)向上蚂四,以此類(lèi)推光戈。一旦抵達(dá)頂層(全局作用域),可能找到了你所需的變量遂赠,也可能沒(méi)找到久妆,但無(wú)論如何查找過(guò)程都將停止。(小編理解這就是傳說(shuō)中的作用域鏈)如果在全局作用域都沒(méi)找到該定義跷睦, 將會(huì)拋出異常筷弦。對(duì)于不同的情況,拋出的異常也會(huì)不一樣抑诸,考慮以下代碼烂琴。

function foo(a){
  console.log(a + b);
  b = a;
}

foo(2);

第一次對(duì)b進(jìn)行RHS查詢時(shí)是無(wú)法找到該變量的。也就是說(shuō)蜕乡,這是一個(gè)“未聲明”的變量奸绷,因?yàn)樵谌魏蜗嚓P(guān)的作用域中都無(wú)法找到它。包括全局作用域层玲,也無(wú)法找到這個(gè)變量号醉。如果RHS查詢?cè)谒星短椎淖饔糜蛑斜閷げ坏剿璧淖兞浚婢蜁?huì)拋出ReferenceError異常辛块。值得注意的是畔派,ReferenceError是非常重要的異常類(lèi)型。相較之下润绵,當(dāng)引擎執(zhí)行LHS查詢時(shí)线椰,如果在頂層(全局作用域)中也無(wú)法找到目標(biāo)變量,全局作用域中就會(huì)創(chuàng)建一個(gè)具有該名稱的變量授药,并將其返還給引擎士嚎,前提是程序運(yùn)行在非“嚴(yán)格模式”下。如果RHS查詢找到了一個(gè)變量悔叽,但是你嘗試對(duì)這個(gè)變量的值進(jìn)行不合理的操作,比如試圖對(duì)一個(gè)非函數(shù)類(lèi)型的值進(jìn)行函數(shù)調(diào)用爵嗅,或者引用null或undefined類(lèi)型的值中的屬性娇澎,那么引擎會(huì)拋出另外一種類(lèi)型的異常,叫作TypeError睹晒。ReferenceError同作用域判別失敗相關(guān)趟庄,而TypeError則代表作用域判別成功了括细,但是對(duì)結(jié)果的操作是非法或不合理的。鑒于小編是第一次在公眾號(hào)中把JavaScript往更深層次去研究戚啥,中間難免有錯(cuò)誤或者理解上的失誤奋单,要是發(fā)現(xiàn)了,還請(qǐng)大家多多指出猫十。小編愿意和大家在js這條路上共同進(jìn)步览濒。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市拖云,隨后出現(xiàn)的幾起案子贷笛,更是在濱河造成了極大的恐慌,老刑警劉巖宙项,帶你破解...
    沈念sama閱讀 219,539評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件乏苦,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡尤筐,警方通過(guò)查閱死者的電腦和手機(jī)汇荐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,594評(píng)論 3 396
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)盆繁,“玉大人掀淘,你說(shuō)我怎么就攤上這事「幕” “怎么了繁疤?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,871評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)秕狰。 經(jīng)常有香客問(wèn)我稠腊,道長(zhǎng),這世上最難降的妖魔是什么鸣哀? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,963評(píng)論 1 295
  • 正文 為了忘掉前任架忌,我火速辦了婚禮,結(jié)果婚禮上我衬,老公的妹妹穿的比我還像新娘叹放。我一直安慰自己,他們只是感情好挠羔,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,984評(píng)論 6 393
  • 文/花漫 我一把揭開(kāi)白布井仰。 她就那樣靜靜地躺著,像睡著了一般破加。 火紅的嫁衣襯著肌膚如雪俱恶。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,763評(píng)論 1 307
  • 那天,我揣著相機(jī)與錄音合是,去河邊找鬼了罪。 笑死,一個(gè)胖子當(dāng)著我的面吹牛聪全,可吹牛的內(nèi)容都是我干的泊藕。 我是一名探鬼主播,決...
    沈念sama閱讀 40,468評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼难礼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼娃圆!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起鹤竭,我...
    開(kāi)封第一講書(shū)人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤踊餐,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后臀稚,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體吝岭,經(jīng)...
    沈念sama閱讀 45,850評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,002評(píng)論 3 338
  • 正文 我和宋清朗相戀三年吧寺,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了窜管。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,144評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡稚机,死狀恐怖幕帆,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情赖条,我是刑警寧澤失乾,帶...
    沈念sama閱讀 35,823評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站纬乍,受9級(jí)特大地震影響碱茁,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜仿贬,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,483評(píng)論 3 331
  • 文/蒙蒙 一纽竣、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧茧泪,春花似錦蜓氨、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,026評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至嗜侮,卻和暖如春刀荒,著一層夾襖步出監(jiān)牢的瞬間代嗤,已是汗流浹背棘钞。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,150評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工缠借, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人宜猜。 一個(gè)月前我還...
    沈念sama閱讀 48,415評(píng)論 3 373
  • 正文 我出身青樓泼返,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親姨拥。 傳聞我的和親對(duì)象是個(gè)殘疾皇子绅喉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,092評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 官方中文版原文鏈接 感謝社區(qū)中各位的大力支持柴罐,譯者再次奉上一點(diǎn)點(diǎn)福利:阿里云產(chǎn)品券,享受所有官網(wǎng)優(yōu)惠憨奸,并抽取幸運(yùn)大...
    HetfieldJoe閱讀 3,232評(píng)論 5 34
  • 如果我的文章對(duì)你有用排宰,請(qǐng)給我一個(gè)贊似芝,讓我有繼續(xù)堅(jiān)持的動(dòng)力/微笑。原創(chuàng)文章板甘,此文章僅供學(xué)習(xí)參考使用党瓮,歡迎訪問(wèn)我的個(gè)人...
    我就是z閱讀 489評(píng)論 0 3
  • (一)作用域是什么? 1. JavaScript代碼的執(zhí)行過(guò)程 JavaScript代碼的整個(gè)執(zhí)行過(guò)程盐类,分為兩個(gè)階...
    虹貓1992閱讀 2,597評(píng)論 0 7
  • 特別說(shuō)明在跳,為便于查閱枪萄,文章轉(zhuǎn)自https://github.com/getify/You-Dont-Know-JS...
    殺破狼real閱讀 581評(píng)論 0 0
  • 程序需要存儲(chǔ)變量中的值,并且能在之后對(duì)這個(gè)值進(jìn)行訪問(wèn)或修改硬毕。這些變量存儲(chǔ)在哪里呻引?程序如何找到他們?這些問(wèn)題需要一套...
    zyanfly閱讀 268評(píng)論 0 1