3 回答

TA貢獻(xiàn)1883條經(jīng)驗(yàn) 獲得超3個(gè)贊
您的問(wèn)題的答案在您的標(biāo)題中:變量位于“時(shí)間死區(qū)”中,這只是您所看到的行為的名稱。
與以
var
undefined 開頭的變量聲明的變量不同,let
變量在其定義被評(píng)估之前不會(huì)被初始化。在初始化之前訪問(wèn)變量會(huì)導(dǎo)致ReferenceError
.?從塊的開始到處理初始化,變量都處于“時(shí)間死區(qū)”。
塊的開始是開頭{
和你的console.log(a)
comes beforelet
語(yǔ)句,所以它在這個(gè)“死區(qū)”。
為什么會(huì)這樣?因?yàn)樗梢詭椭绦騿T檢測(cè)由于在不同范圍內(nèi)具有相同名稱的變量之間的混淆而導(dǎo)致的代碼錯(cuò)誤。

TA貢獻(xiàn)1765條經(jīng)驗(yàn) 獲得超5個(gè)贊
嵌套塊將創(chuàng)建一個(gè)新的塊作用域詞法環(huán)境。
內(nèi)部a變量在該范圍內(nèi)聲明,但在初始化之前訪問(wèn),因此出現(xiàn)錯(cuò)誤。
內(nèi)部范圍let a聲明覆蓋了var a聲明,所以它是一個(gè)不同的變量,就像你這樣寫一樣:
var a = 6;
{
console.log(a2)
let a2 =55
}

TA貢獻(xiàn)1854條經(jīng)驗(yàn) 獲得超8個(gè)贊
除了上述兩個(gè)答案之外,該語(yǔ)句let a = 55實(shí)際上是兩個(gè)語(yǔ)句合二為一:let a- 聲明 - 和a = 55- 賦值。由于 Javascript 的提升規(guī)則,聲明在進(jìn)入塊時(shí)處理,但賦值保留其詞法位置。
所以塊:
var a = 6
{
console.log(a)
let a = 55
}
在語(yǔ)義上等同于:
var a = 6
{
let a
console.log(a)
a = 55
}
因?yàn)榫植柯暶鱝屏蔽了同名的全局變量,到console.log(a)執(zhí)行時(shí)a已經(jīng)聲明但還沒有賦值。
添加回答
舉報(bào)