鍍金池/ 問答/HTML/ 重復(fù)聲明同一個(gè)變量

重復(fù)聲明同一個(gè)變量

下面有兩個(gè)小栗子

var a = 1;
var a = 2;
console.log(a); // 2
var a = 1;
var a;
console.log(a); //1

上面第一個(gè)栗子很好理解,再次聲明同一個(gè)變量會覆蓋掉之前的變量,但是第二個(gè)栗子為什么不是輸出undefined呢?

我有一個(gè)理解方式不知道對不對,可以從變量提升的角度去理解,上面的代碼經(jīng)過變量提升就可以改寫成下面這樣,因?yàn)樽兞刻嵘惶嵘暶鞑惶嵘x值

var a;
var a;
a = 1;
console.log(a);

剛剛?cè)ゲ榱速Y料,參考《JavaScript高級程序設(shè)計(jì)》第7.3章節(jié),原話如下

JavaScript從來不會告訴你是否多次聲明了同一個(gè)變量;遇到這種情況,它只會對后續(xù)的聲明視而不見(不過,它會執(zhí)行后續(xù)聲明中的變量初始化)。

回答
編輯回答
九年囚

你的理解是對的,就是變量提升了

2017年9月30日 00:01
編輯回答
網(wǎng)妓

你的理解是對的,就是這么回事兒。

2018年2月28日 19:17
編輯回答
爛人

忍不住立馬去查了資料,參考《JavaScript高級程序設(shè)計(jì)》第7.3章節(jié),原話如下

JavaScript從來不會告訴你是否多次聲明了同一個(gè)變量;遇到這種情況,它只會對后續(xù)的聲明視而不見(不過,它會執(zhí)行后續(xù)聲明中的變量初始化)。

因此只是JavaScript的特性,和變量提升無關(guān)。

2017年3月21日 15:22
編輯回答
蔚藍(lán)色

理解正確,javascript中存在變量提升,建議去看一下es6的let聲明和const聲明

2017年7月30日 13:03
編輯回答
孤星
hoist
2018年5月11日 15:27
編輯回答
奧特蛋
不在這敘述大段的文字來講述了。如果想要深入了解這個(gè)原因,或者從規(guī)范的角度來解釋??梢钥聪吕习嬉?guī)范中,執(zhí)行上下文和變量對象,激活對象的解釋,這些概念都有中文翻譯的博客之類的。這幾個(gè)概念會從實(shí)現(xiàn)原理上通俗的講下,在解釋器階段和代碼執(zhí)行階段,一個(gè)標(biāo)識符是如何與一個(gè)值進(jìn)行綁定的。還有諸如,一個(gè)變量名為a和函數(shù)名為a,同名情況下,執(zhí)行上下文會取哪個(gè)值,諸如此類問題,對你理解詞法環(huán)境(新版規(guī)范)和作用域,作用域鏈,閉包都有很大幫助。而變量聲明提升,也只是在這些基礎(chǔ)概念上,后人總結(jié)出來的一句話。
2017年2月22日 23:14