变量作用域(通俗 + 清晰讲解,适合编程入门)

变量作用域 = 变量能被访问、使用的范围,出了这个范围,变量就失效、找不到了。

主流分 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. 一句话总结

  1. 全局:全程序可用
  2. 函数:函数内可用
  3. 块级{} 内可用(let/const)
  4. 内层找外层,外层找不到内层
相关推荐
铁皮饭盒15 分钟前
Next.js 风格路由内置?Bun FileSystemRouter 凭啥这么香
javascript
乘风gg15 分钟前
多 Agent 不是万能的!搞懂这 5 个原则,少走 1 年弯路!
前端·agent·ai编程
猩猩程序员1 小时前
Vercel 推出 Agent 框架 Eve:让 AI Agent 像写 Web 应用一样简单
前端
小林ixn1 小时前
别再背八股了!从 5 个真实场景彻底搞懂 JavaScript 的 this
javascript
爱读源码的大都督1 小时前
Claude Code源码分析(三):为什么系统提示词中需要有tools呢?
前端·人工智能·后端
爱勇宝1 小时前
Claude Code 被曝暗藏“隐形检测”代码:封代理不是最可怕的,可怕的是你根本不知道它在干什么
前端·后端·程序员
小牛不牛的程序员2 小时前
我用 Claude Code 半天撸完了一个完整网站,AI 编程到底提升了多少效率?
前端
东风破_2 小时前
JavaScript 面试常考的字符串算法:从反转字符串到回文判断
前端·javascript
巴勒个啦2 小时前
D3.js 入门实战:用力导向图可视化项目依赖关系
javascript
ITOM运维行者2 小时前
从零搭建企业级服务器监控体系:踩坑实录与架构设计
前端·后端