3 回答

TA貢獻(xiàn)1851條經(jīng)驗(yàn) 獲得超3個(gè)贊
您的問題的答案就在您的標(biāo)題中:該變量位于“暫時(shí)死區(qū)”,這只是您所看到的行為的名稱。
與使用 聲明的變量不同
var
,變量將以未定義的值開始,let
變量在其定義被求值之前不會(huì)被初始化。在初始化之前訪問變量會(huì)產(chǎn)生ReferenceError
.?從塊開始直到處理初始化為止,該變量處于“臨時(shí)死區(qū)”。
塊的開始是開頭{
,您的console.log(a)
來之前let
聲明,因此它位于這個(gè)“死區(qū)”。
為什么會(huì)這樣呢?因?yàn)樗梢詭椭绦騿T檢測代碼中由于不同作用域中同名變量之間的混淆而導(dǎo)致的錯(cuò)誤。

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

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