ES2015(ES6) 新增加了兩個重要的 JavaScript 關鍵字: let 和 const。
let 聲明的變量只在 let 命令所在的代碼塊內有效。
const 聲明一個只讀的常量,一旦聲明,常量的值就不能改變。
在 ES6 之前,JavaScript 只有兩種作用域: 全局變量 與 函數內的局部變量。
在函數外聲明的變量作用域是全局的:
var carName = "Volvo";
// 這里可以使用 carName 變量
function myFunction() {
// 這里也可以使用 carName 變量
}
局部變量:函數內使用 var 聲明的變量只能在函數內訪問,如果不使用 var 則是全局變量。
// 這里不能使用 carName 變量
function myFunction() {
var carName = "Volvo";
// 這里可以使用 carName 變量
}
// 這里不能使用 carName 變量
JavaScript 塊級作用域(Block Scope)
使用 var 關鍵字聲明的變量不具備塊級作用域的特性,它在 {} 外依然能被訪問到。
{
let x = 2;
}
// 這里不能使用 x 變量
重新定義變量
使用 var 關鍵字重新聲明變量可能會帶來問題。
在塊中重新聲明變量也會重新聲明塊外的變量:
var x = 10;
// 這里輸出 x 為 10
{
var x = 2;
// 這里輸出 x 為 2
}
// 這里輸出 x 為 2
let 關鍵字就可以解決這個問題,因為它只在 let 命令所在的代碼塊 {} 內有效。
var x = 10;
// 這里輸出 x 為 10
{
let x = 2;
// 這里輸出 x 為 2
}
// 這里輸出 x 為 10
循環作用域
使用 var 關鍵字:
var i = 5;
for (var i = 0; i < 10; i++) {
// 一些代碼...
}
// 這里輸出 i 為 10
使用 let 關鍵字:
var i = 5;
for (let i = 0; i < 10; i++) {
// 一些代碼...
}
// 這里輸出 i 為 5
在第一個實例中,使用了 var 關鍵字,它聲明的變量是全局的,包括循環體內與循環體外。
在第二個實例中,使用 let 關鍵字, 它聲明的變量作用域只在循環體內,循環體外的變量不受影響。
HTML 代碼中使用全局變量
在 JavaScript 中, 全局作用域是針對 JavaScript 環境。
在 HTML 中, 全局作用域是針對 window 對象。
使用 var 關鍵字聲明的全局作用域變量屬于 window 對象:
var carName = "Volvo";
// 可以使用 window.carName 訪問變量
let carName = "Volvo";
// 不能使用 window.carName 訪問變量
const 關鍵字
const 用于聲明一個或多個常量,聲明時必須進行初始化,且初始化后值不可再修改。
const
定義常量與使用let
定義的變量相似:
兩者還有以下兩點區別:
總結筆記:
使用var關鍵字聲明的全局作用域變量屬于window對象。
使用let關鍵字聲明的全局作用域變量不屬于window對象。
使用var關鍵字聲明的變量在任何地方都可以修改。
在相同的作用域或塊級作用域中,不能使用let關鍵字來重置var關鍵字聲明的變量。
在相同的作用域或塊級作用域中,不能使用let關鍵字來重置let關鍵字聲明的變量。
let關鍵字在不同作用域,或不用塊級作用域中是可以重新聲明賦值的。
在相同的作用域或塊級作用域中,不能使用const關鍵字來重置var和let關鍵字聲明的變量。
在相同的作用域或塊級作用域中,不能使用const關鍵字來重置const關鍵字聲明的變量
const 關鍵字在不同作用域,或不同塊級作用域中是可以重新聲明賦值的:
var關鍵字定義的變量可以先使用后聲明。
let關鍵字定義的變量需要先聲明再使用。
const關鍵字定義的常量,聲明時必須進行初始化,且初始化后不可再修改。
轉自菜鳥教程
該文章在 2024/6/28 15:28:44 編輯過