什么是作用域_Javascript变量在哪里有效

17次阅读

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

什么是作用域_Javascript 变量在哪里有效

作用域(Scope)指的是 JavaScript 中变量、函数等标识符的可访问范围,也就是“变量在哪里能被读取或修改”。简单说,它决定了代码中某个变量是否“看得见”、能不能用。

全局作用域

在函数外部直接声明的变量属于全局作用域,在整个脚本中都能访问。

  • 浏览器 中,全局变量会自动挂载到 window 对象上(如 var a = 1window.a === 1
  • 使用 let/const 在全局块级作用域声明,不会成为 window 的属性,但仍属于全局作用域(可在任何地方访问,除非被嵌套作用域遮蔽)

函数作用域

function 声明的函数内部,用 var 声明的变量只在该函数内有效。

  • var 有变量提升(hoisting),但作用域仍限于函数体
  • 函数内部定义的函数也拥有自己的函数作用域,可访问外层函数的变量(闭包基础)

块级作用域(ES6 新增)

{} 包裹的代码块(如 ifforwhile 或任意 {})中,用 letconst 声明的变量仅在该块内有效。

立即学习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 是块级作用域,所有作用域都遵循自内向外的查找规则。

以上就是什么是

星耀云
版权声明:本站原创文章,由 星耀云 2025-12-23发表,共计887字。
转载说明:转载本网站任何内容,请按照转载方式正确书写本站原文地址。本站提供的一切软件、教程和内容信息仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。
text=ZqhQzanResources