JavaScript中 沒有 塊級作用域,“塊級作用域”中聲明的變數將被添加到 當前 的執行環境中 在JavaScript中,由for語句創建的變數,即使在for迴圈執行結束後,也依舊會存在於迴圈外部的執行環境中。 javascript function add(num1, num2) { var ...
JavaScript中沒有塊級作用域,“塊級作用域”中聲明的變數將被添加到當前的執行環境中
if(true) {
var color = "blue";
}
console.log(color); // "blue"
function test() {
if(true) {
var color = "blue"; // (當前執行環境為函數test的局部作用域,函數外部無法訪問,內部可以訪問)
}
console.log("blue"); // "blue"
function inner() {
console.log(color); // "blue"
}
inner();
}
test();
console.log(color); // ReferenceError: color is not defined
在JavaScript中,由for語句創建的變數,即使在for迴圈執行結束後,也依舊會存在於迴圈外部的執行環境中。
for(var i = 0; i < 10; i++) {
var color = "blue";
}
console.log(i); // 10
console.log(color); // "blue"
使用var聲明的變數會自動被添加到最接近的環境中。在函數內部,最接近的環境就是函數的局部環境;在with語句中,最接近的環境是函數環境。
如果初始化變數時沒有使用var聲明,該變數會自動被添加到全局環境。
function add(num1, num2) {
var sum = num1 + num2; // 用var聲明
return sum;
}
console.log(add(10, 20)); // 30
console.log(sum); // ReferenceError: sum is not defined
function add(num1, num2) {
sum = num1 + num2; // 沒有使用var聲明
return sum;
}
console.log(add(10, 20)); // 30
console.log(sum); // 30
如果局部環境中存在著同名標識符,就不會使用位於父環境中的標識符。
var color = "blue";
function getColor() {
console.log(color); // undefined (變數提升)
var color = "red";
console.log(color); // red
console.log(window.color); // blue
return color;
}
console.log('return: ', getColor()); // return: red
console.log(color); // blue