作用域指变量、函数等标识符的可访问范围;全局作用域中 var 声明变量挂载 window,let/const 不挂载但仍全局可见;函数作用域限于 function 内;块级作用域由 {} 和 let/const 定义;变量查找遵循自内向外的作用域链。

作用域(Scope)指的是 JavaScript 中变量、函数等标识符的可访问范围,也就是“变量在哪里能被读取或修改”。简单说,它决定了代码中某个变量是否“看得见”、能不能用。
全局作用域
在函数外部直接声明的变量属于全局作用域,在整个脚本中都能访问。
- 浏览器 中,全局变量会自动挂载到 window 对象上(如
var a = 1→window.a === 1) - 使用 let/const 在全局块级作用域声明,不会成为
window的属性,但仍属于全局作用域(可在任何地方访问,除非被嵌套作用域遮蔽)
函数作用域
用 function 声明的函数内部,用 var 声明的变量只在该函数内有效。
-
var有变量提升(hoisting),但作用域仍限于函数体 - 函数内部定义的函数也拥有自己的函数作用域,可访问外层函数的变量(闭包基础)
块级作用域(ES6 新增)
由 {} 包裹的代码块(如 if、for、while 或任意 {})中,用 let 和 const 声明的变量仅在该块内有效。
立即学习“Java 免费学习笔记(深入)”;
let x = 1; if (true) {let x = 2; console.log(x); } console.log(x); // 输出 2,然后 1- 重复声明同名
let/const会报错;var允许重复声明(但不推荐)
作用域链与查找规则
当访问一个变量时,JavaScript 引擎会从当前作用域开始查找,没找到就向上一级作用域找,直到全局作用域。这个逐级向上搜索的路径叫“作用域链”。
- 内层可以访问外层变量,但外层不能访问内层变量
- 如果内外层有同名变量,内层会“遮蔽”(shadow)外层变量
- 函数定义时的作用域决定其作用域链,与调用位置无关(静态 / 词法作用域)
理解作用域是写出可靠、无意外变量冲突代码的基础。重点记住:var 是函数作用域,let/const 是块级作用域,所有作用域都遵循自内向外的查找规则。
以上就是什么是