全局作用域: {}外面的作用域,是全局作用域块级作用域: 只要{ }没有和函数结合在一起,就是块级作用域局部作用域(函数作用域): 函数后面的{}中的作用域
2-1 var 声明作用域
关键的问题在于,使用 var 操作符定义的变量会成为包含它的函数的局部变量
function test() { var message = "hi"; // 局部变量 } test(); console.log(message); // 出错// 在函数内定义变量时省 略 var 操作符,可以创建一个全局变量function test() { message = "hi"; // 全局变量 } test(); console.log(message); // "hi"
2-1-1 var 声明提升
使用这个关键字声明的变量会自动提升到函数作用域 顶部: function foo() { console.log(age); var age = 26; } foo(); // undefined 但不会报错
2-2 let 声明
let 跟 var 的作用差不多,但有着非常重要的区别。明显的区别是,let 声明的范围是块作用域, 而 var 声明的范围是函数作用域。
1. 暂时性死区
let 与 var 的另一个重要的区别,就是 let 声明的变量不会在作用域中被提升。
2. 全局声明
与 var 关键字不同,使用 let 在全局作用域中声明的变量不会成为 window 对象的属性(var 声明的变量则会)
3.条件声明
var 存在变量提升 let没有var 可以重复声明 let不可以
4. for 循环中的 let 声明
迭代变量的作用域仅限于 for 循环块内部: for (let i = 0; i < 5; ++i) { // 循环逻辑 } console.log(i); // i 没有定义
2-3 const 声明
const 的行为与 let 基本相同,唯一一个重要的区别是 用它声明变量时必须同时初始化变量且尝试修改 const 声明的变量会导致运行时错误