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

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

主流分 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. 内层找外层,外层找不到内层
相关推荐
weelinking1 小时前
【claude】15_Claude使用经验与最佳实践
前端·人工智能·python·sql·数据挖掘·前端框架·github
XS0301061 小时前
HTML 入门教程
前端·html
刻BITTER1 小时前
Alpine.js + Chart.js 踩坑记:一次 Maximum Call Stack Exceeded 排查之旅
开发语言·javascript·ecmascript
之歆1 小时前
Day15_JavaScript DOM 事件完全指南:从基础到实战(下)
开发语言·javascript·ecmascript
弹简特1 小时前
【Vue3速成】02-vue工程化目录结构+执行原理
前端·vue.js·npm
_codemonster1 小时前
JSP 、Thymeleaf 、 JavaScript 和Vue
java·javascript·vue.js
杖雍皓1 小时前
Markstream-VUE:构建高性能流式 Markdown 渲染器
前端·javascript·vue.js·markdown·流式输出
ZC跨境爬虫2 小时前
模块化烹饪小程序开发日记 Day6:(菜谱列表接口开发与日志调试实践)
前端·javascript·css·ui·微信小程序·html
KaMeidebaby2 小时前
卡梅德生物技术快报|适配体筛选技术架构演进:SPARK-seq 高通量平台原理与技术流程解析
大数据·前端·其他·百度·架构·spark·新浪微博