欧美成人精品手机在线观看_69视频国产_动漫精品第一页_日韩中文字幕网 - 日本欧美一区二区

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

【JavaScript】不用 var!let 和 const 的正確用法,被忽略的細(xì)節(jié)

admin
2025年3月29日 21:32 本文熱度 75

目前,let 和 const 關(guān)鍵字已經(jīng)取代了傳統(tǒng)的 var,帶來了更合理的作用域規(guī)則和更嚴(yán)格的使用限制。然而,即使是有經(jīng)驗(yàn)的開發(fā)者,也會(huì)忽略一些微妙的細(xì)節(jié)。

var 的問題:為什么不要用它

在深入了解 let 和 const 之前,有必要先理解為什么我們不要用 var

  1. 函數(shù)作用域而非塊級(jí)作用域

    if (true) {
     var x = 10;
    }
    console.log(x); // 10,變量 x 泄露到外部作用域
  2. 變量提升(Hoisting)帶來的困惑

    console.log(x); // undefined,而非報(bào)錯(cuò)
    var x = 5;
  3. 允許重復(fù)聲明

    var user = "張三";
    var user = "李四"; // 不報(bào)錯(cuò),靜默覆蓋
  4. 全局聲明成為全局對象的屬性

    var global = "我是全局變量";
    console.log(window.global); // "我是全局變量"(瀏覽器環(huán)境)

這些特性導(dǎo)致了許多難以追蹤的 bug,尤其在大型應(yīng)用程序中。

let 的核心特性:被忽略的細(xì)節(jié)

1. 暫時(shí)性死區(qū)(Temporal Dead Zone)

這可能是 let 最容易被忽略的特性:

console.log(x); // ReferenceError: x is not defined
let x = 5;

與 var 不同,let 聲明的變量存在"暫時(shí)性死區(qū)"(TDZ)。從塊作用域開始到變量聲明之前,該變量都是不可訪問的。這并非簡單的"不提升",而是一種更精細(xì)的機(jī)制。

let x = 10;
function example() {
 // 從這里開始,x 進(jìn)入 TDZ
 console.log(x); // ReferenceError
 
 let x = 20; // 這里 x 離開 TDZ
}

被忽略的細(xì)節(jié):即使外部作用域已有同名變量,內(nèi)部作用域的暫時(shí)性死區(qū)仍然會(huì)阻止訪問。

2. 真正的塊級(jí)作用域

let 聲明的變量嚴(yán)格遵循塊級(jí)作用域規(guī)則,這點(diǎn)經(jīng)常被低估:

for (let i = 0; i < 3; i++) {
 setTimeout(() => console.log(i), 100);
}
// 輸出:0, 1, 2

for (var i = 0; i < 3; i++) {
 setTimeout(() => console.log(i), 100);
}
// 輸出:3, 3, 3

被忽略的細(xì)節(jié):每次循環(huán)迭代,let 聲明都會(huì)創(chuàng)建一個(gè)新的變量實(shí)例,這在處理閉包時(shí)尤為重要。

3. 不污染全局對象

雖然知道 let 不會(huì)成為全局對象的屬性,但有一個(gè)細(xì)節(jié)常被忽略:

被忽略的細(xì)節(jié):全局 let 變量存儲(chǔ)在稱為"腳本作用域"的特殊環(huán)境中,而非全局對象上。

const 的核心特性:被誤解的不變性

1. 對象和數(shù)組的可變性

許多開發(fā)者誤以為 const 聲明的對象或數(shù)組是完全不可變的:

被忽略的細(xì)節(jié)const 只保證引用不變,而非內(nèi)容不變。要?jiǎng)?chuàng)建不可變對象,需要使用 Object.freeze()

但要注意,Object.freeze() 只是淺凍結(jié):

深度凍結(jié)需要遞歸應(yīng)用 Object.freeze()

2. 聲明時(shí)必須初始化

這似乎是顯而易見的,但容易被忽略的是初始化的時(shí)機(jī):

被忽略的細(xì)節(jié)const 聲明的變量不能被賦予新值,但這并不意味著它的內(nèi)容不可變。

3. 性能考慮

一個(gè)常被忽略的事實(shí)是,在某些 JavaScript 引擎中,const 聲明可能會(huì)有輕微的性能優(yōu)勢:

引擎可以確保這些值永遠(yuǎn)不會(huì)改變,從而可能進(jìn)行常量折疊等優(yōu)化。

實(shí)用的使用模式和最佳實(shí)踐

1. 默認(rèn)使用 const,必要時(shí)退回到 let

這種方式可以最大限度減少代碼中的變量重新賦值,提高可讀性和可維護(hù)性。

2. 解構(gòu)賦值中的 let 和 const

被忽略的細(xì)節(jié):函數(shù)參數(shù)解構(gòu)本質(zhì)上是 const 聲明,不能重新賦值。

3. 循環(huán)中的 let vs const

被忽略的細(xì)節(jié)for-of 和 for-in 循環(huán)中使用 const 是合法的,因?yàn)槊看蔚紩?huì)創(chuàng)建新的綁定。

深入理解:letconst 的內(nèi)部工作機(jī)制

理解 JavaScript 引擎如何處理這些聲明,有助于避免常見陷阱:

// 簡化的內(nèi)部處理流程
function example() {
 // 1. 創(chuàng)建詞法環(huán)境
 // 2. 對 let/const 聲明進(jìn)行"未初始化"標(biāo)記(TDZ 開始)
 
 // console.log(x); // 如果取消注釋,會(huì)報(bào)錯(cuò):x 在 TDZ 中
 
 let x = 10; // x 從 TDZ 中解除,并賦值為 10
 
 if (true) {
   // 創(chuàng)建新的塊級(jí)詞法環(huán)境
   const y = 20;
   x = 30; // 可以訪問外部 x
   // y 僅在此塊中可用
 }
 
 // console.log(y); // 如果取消注釋,會(huì)報(bào)錯(cuò):y 不在此作用域
}

詞法環(huán)境(Lexical Environment)和變量環(huán)境(Variable Environment)的區(qū)別是 JavaScript 引擎如何區(qū)分處理不同類型的聲明。


閱讀原文:原文鏈接


該文章在 2025/3/31 11:15:07 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲(chǔ)管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved