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

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

主流分 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. 内层找外层,外层找不到内层
相关推荐
问心无愧051341 分钟前
ctf show web入门160 161
前端·笔记
李小白661 小时前
第四天-WEB服务器基本原理,IIS服务
运维·服务器·前端
humcomm2 小时前
AI编程时代新前端职位
前端·ai编程
好家伙VCC2 小时前
Web Components主题热切换方案揭秘
java·前端
甲维斯2 小时前
Kimi版超级玛丽效果“惊人”,配额不足5厘米!
前端·人工智能
hboot2 小时前
AI工程师第一课 - Python
前端·后端·python
凉菜凉凉2 小时前
AI时代,被抛弃的前端
前端·ai
console.log('npc')3 小时前
AI前端工程与生成式UI学习路线
前端·人工智能·ui
huangdong_3 小时前
淘宝商品SKU图自动分类技术深度解析:从DOM解析到智能归档
开发语言·javascript·ecmascript
梦曦i3 小时前
uni-router v1.1.1发布:守卫超时保护+路由监听
前端·uni-app