变量作用域 = 变量能被访问、使用的范围,出了这个范围,变量就失效、找不到了。
主流分 4 种:全局作用域、函数作用域、块级作用域、作用域链。下面用最简单的话讲清楚。
1. 全局作用域(Global)
- 定义:函数 / 代码块外面直接定义的变量
- 特点:整个程序都能用,随处访问
js
let name = "小明"; // 全局变量
function test(){
console.log(name); // 可以用
}
2. 函数作用域(Function)
- 定义:在函数内部定义的变量
- 特点:函数外面访问不到,只有函数内可用
js
function test(){
let age = 18; // 函数内变量
}
console.log(age); // 报错,外面用不了
3. 块级作用域(Block,ES6 重点)
let / const 才有,var 没有
- 块:
{}包裹的区域(if、for、while、{}) - 特点:大括号外面不能用
js
if(true){
let num = 10;
}
console.log(num); // 报错
区别:
var:函数作用域,无块级作用域,可变量提升let/const:块级作用域,不允许重复声明
4. 作用域链(核心)
内层能访问外层,外层不能访问内层
查找变量:先在自己作用域找 → 找不到往父级找 → 直到全局
js
let a = 1;
function f1(){
let b = 2;
function f2(){
let c = 3;
console.log(a,b,c); // 都能找到
}
}
5. 一句话总结
- 全局:全程序可用
- 函数:函数内可用
- 块级 :
{}内可用(let/const) - 内层找外层,外层找不到内层