二螺捐、深入之聲明前置

0x00颠悬、引言

為了對(duì)JavaScript的作用域和作用域鏈有一個(gè)更好的理解,我們就需要了解JS這門語言的一個(gè)機(jī)制定血,即聲明前置赔癌。

0x01、從變量的聲明前置說起

我比較喜歡從一些小的demo來說起和加深自己對(duì)JavaScript這門語言機(jī)制的理解澜沟,那么聲明前置這個(gè)也不另外

  • demo1
    console.log(a)      // undefined
    var a = 1
    console.log(a)     //1
    

第二個(gè)console.log(a) 打印出1我們好理解届榄,那么上面為什么第一個(gè)console會(huì)打印出undefined?
這里就不得不提一直說的聲明前置倔喂,其實(shí)var a = 1可以拆解為var aa = 1這樣兩個(gè)部分了铝条,var a是對(duì)變量a的聲明,a = 1是對(duì)變量a的賦值席噩,所謂聲明前置就JS引擎在解析這段代碼的時(shí)候班缰,會(huì)將var a聲明放置在最前面,即可以改寫為以下代碼

  • demo1改寫

var a //變量a聲明前置了
console.log(a) // undefined
a = 1
console.log(a) //1

下面我們?cè)賮砜匆粋€(gè)例子
- demo2
 

console.log(a) // undefined
if (false){
var a
}


這里我們將var a放置在if 語句中悼枢,還會(huì)聲明被前置么埠忘,結(jié)果是當(dāng)然,因?yàn)樵赱深入之作用域](http://www.reibang.com/p/636c5eb548e2)中我們以及知道在JS這門語言中只有全局作用域和函數(shù)作用域馒索,無塊級(jí)作用域(ES6有新增)莹妒,**因而var a 即使在if/for里面,也會(huì)被前置的**


##### 0x02绰上、關(guān)于函數(shù)的聲明前置
我們知道函數(shù)有多種的調(diào)用方式旨怠,但我們這里主要討論函數(shù)的聲明前置,所以當(dāng)用到函數(shù)的調(diào)用就以最簡單的一種函數(shù)調(diào)用模式為例
- demo3 

fn(2,3); //5
function fn(a,b) {
return a+b;
var c = 1
}

在這個(gè)簡單的函數(shù)調(diào)用中蜈块,在JS中將定義的函數(shù)進(jìn)行一個(gè)聲明前置鉴腻,確保它在被調(diào)用前以及被定義了,下面我們可以改寫為以下形式
- demo3改寫

function fn(a,b) { //全局作用域下定義的函數(shù)fn聲明前置
var c //函數(shù)作用域內(nèi)聲明變量c前置
return a+b;
c = 1
}
fn(2,3); //5

#### 0x03百揭、下面舉出幾個(gè)復(fù)雜一點(diǎn)的例子
> 1.若不報(bào)錯(cuò)爽哎,下面代碼輸出什么?

var y = 10;

if (!(x in window)) {
    var x = 10;
} else {
    ++y;
}

alert(x);        //undefined,var a 即使在if/for里面器一,也會(huì)被前置的,
                 //但a=10的賦值還會(huì)停留在if(){...}中
alert(y);            //11
> 2.重復(fù)聲明兩個(gè)函數(shù)會(huì)怎樣课锌?

var m= 1, j = k = 0;
function add(n) {
return n = n+1;
  }
y = add(m); //4,由聲明前置我們可以知道后一個(gè)函數(shù)將在y調(diào)用前聲明并覆蓋掉前一個(gè)函數(shù)的聲明(同名)
function add(n) {
return n = n + 3;
}
z = add(m); //4,z和y的指針其實(shí)指向的其實(shí)是同一個(gè)函數(shù)

> 3.對(duì)下面進(jìn)行聲明前置的改寫

a = 2
b()

var a

function c(){
console.log(a)
}
function b(){
a = 1
c()
var a
}
/------改寫------/
var a //全局作用域內(nèi)的變量a提升
function c(){ //聲明函數(shù)的變量提升
console.log(a) //重點(diǎn) 祈秕,此時(shí)的a指的是全局變量的a
}
function b(){ //聲明函數(shù)的變量提升
var a //函數(shù)作用域內(nèi)的變量a提升
a = 1
c() //c()函數(shù)被調(diào)用
}
a = 2
b() //2

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末渺贤,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子踢步,更是在濱河造成了極大的恐慌癣亚,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,807評(píng)論 6 518
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件获印,死亡現(xiàn)場離奇詭異述雾,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)兼丰,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,284評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門玻孟,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人鳍征,你說我怎么就攤上這事黍翎。” “怎么了艳丛?”我有些...
    開封第一講書人閱讀 169,589評(píng)論 0 363
  • 文/不壞的土叔 我叫張陵匣掸,是天一觀的道長趟紊。 經(jīng)常有香客問我,道長碰酝,這世上最難降的妖魔是什么霎匈? 我笑而不...
    開封第一講書人閱讀 60,188評(píng)論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮送爸,結(jié)果婚禮上铛嘱,老公的妹妹穿的比我還像新娘。我一直安慰自己袭厂,他們只是感情好墨吓,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,185評(píng)論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著纹磺,像睡著了一般帖烘。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上爽航,一...
    開封第一講書人閱讀 52,785評(píng)論 1 314
  • 那天蚓让,我揣著相機(jī)與錄音,去河邊找鬼讥珍。 笑死历极,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的衷佃。 我是一名探鬼主播趟卸,決...
    沈念sama閱讀 41,220評(píng)論 3 423
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼氏义!你這毒婦竟也來了锄列?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,167評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤惯悠,失蹤者是張志新(化名)和其女友劉穎邻邮,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體克婶,經(jīng)...
    沈念sama閱讀 46,698評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡筒严,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,767評(píng)論 3 343
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了情萤。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片鸭蛙。...
    茶點(diǎn)故事閱讀 40,912評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖筋岛,靈堂內(nèi)的尸體忽然破棺而出娶视,到底是詐尸還是另有隱情,我是刑警寧澤睁宰,帶...
    沈念sama閱讀 36,572評(píng)論 5 351
  • 正文 年R本政府宣布肪获,位于F島的核電站寝凌,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏贪磺。R本人自食惡果不足惜硫兰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,254評(píng)論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望寒锚。 院中可真熱鬧,春花似錦违孝、人聲如沸刹前。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,746評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽喇喉。三九已至,卻和暖如春校坑,著一層夾襖步出監(jiān)牢的瞬間拣技,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,859評(píng)論 1 274
  • 我被黑心中介騙來泰國打工耍目, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留膏斤,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,359評(píng)論 3 379
  • 正文 我出身青樓邪驮,卻偏偏與公主長得像莫辨,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子毅访,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,922評(píng)論 2 361

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

  • 第2章 基本語法 2.1 概述 基本句法和變量 語句 JavaScript程序的執(zhí)行單位為行(line)沮榜,也就是一...
    悟名先生閱讀 4,153評(píng)論 0 13
  • 工廠模式類似于現(xiàn)實(shí)生活中的工廠可以產(chǎn)生大量相似的商品,去做同樣的事情喻粹,實(shí)現(xiàn)同樣的效果;這時(shí)候需要使用工廠模式蟆融。簡單...
    舟漁行舟閱讀 7,779評(píng)論 2 17
  • 函數(shù)聲明和函數(shù)表達(dá)式有什么區(qū)別 (*)解析器會(huì)率先讀取函數(shù)聲明,并使其在執(zhí)行任何代碼之前可以訪問守呜;函數(shù)表達(dá)式則必須...
    coolheadedY閱讀 391評(píng)論 0 1
  • 1.函數(shù)聲明和函數(shù)表達(dá)式有什么區(qū)別 (*) 區(qū)別: 函數(shù)聲明后面的分號(hào)可加可不加型酥,不加也不影響接下來語句的執(zhí)行,但...
    Sheldon_Yee閱讀 401評(píng)論 0 1
  • soft binary classification Logistics回歸模型要解決的是分類問題弛饭,在之前的二元分...
    JasonDing閱讀 952評(píng)論 0 5