JS作用域没搞懂?看完这篇图解,让变量[生存范围]一目了然

深入理解 V8 引擎与 JavaScript 执行机制

一、 V8 引擎概述

V8 是 Google 开发的高性能 JavaScript 引擎,用于 Chrome 和 Edge 浏览器以及 Node.js。它的核心功能是将 JavaScript 代码转换为机器码并执行。

二、V8 执行JS代码的过程

分词/词法分析(Parsing)​​:将代码分成词法单元。

js 复制代码
const x = 10 + 20
代码片段 Token 类型
const Keyword
x Identifier
= Assignment
10 Number
+ Operator
20 Number

解析和语法分析​​:根据语法规则生成抽象语法树(AST),检查代码是否符合语法规则。

  • 检查 const → 变量声明
  • 检查 x → 变量名
  • 检查 = → 赋值
  • 检查 10 + 20 → 二元运算表达式

代码生成​​: 将 AST 转换为可执行的机器码(或字节码)。

三、 作用域

作用​​: 存放变量的值并能在之后对这个值进行访问和修改。

  1. 全局作用域:在代码最外层声明的变量或函数,可以在任何地方访问。
js 复制代码
count a = 1       //全局作用域
function showGlobal(){
   console.log(a);    //可以访问
}
showGlobal(a)       // 1
 console.log(a);    //1

注意​​:全局变量容易被污染,导致命名冲突。

  1. 函数作用域:在函数内部声明的变量,只能在该函数及其嵌套函数内访问。
js 复制代码
function outer() {
  var funcVar = "I'm in outer"; // 函数作用域变量

  function inner() {
    console.log(funcVar); // 可以访问(闭包)
  }

  inner(); // "I'm in outer"
}

outer();
console.log(funcVar); // ReferenceError: funcVar is not defined
  1. 块级作用域:由 {}(如 ifforwhile) + let/const形成的作用域。
js 复制代码
if (true) {
  let blockVar = "I'm in block"; // 块级作用域变量
  const PI = 3.14; // 块级作用域常量
  console.log(blockVar); // "I'm in block"
}

console.log(blockVar); // ReferenceError: blockVar is not defined
console.log(PI); // ReferenceError: PI is not defined
  • letconst + {}是块级作用域。
  • var没有块级作用域,它会提升到最近的函数或全局作用域:

总结​

  1. ​全局作用域​
  • 最外层,随处可访问。
  • 容易污染全局命名空间,慎用。
  1. ​函数作用域​
  • varfunction 声明的作用域。
  • 支持闭包,内部函数可访问外部变量。
  1. ​块级作用域​
  • letconst 的作用域。
  • 避免变量提升问题,更安全。

​最佳实践​ ​:

✔ 优先使用 let/const(避免 var 的变量提升和泄漏)

✔ 避免滥用全局变量(防止命名冲突)

✔ 合理使用闭包(避免内存泄漏)

四、作用域链

V8 引擎查找变量时,会沿着作用域链向上查找:

  1. 先在当前作用域查找。
  2. 如果找不到,向上一级作用域查找。
  3. 直到全局作用域,如果仍未找到,报 ReferenceError
js 复制代码
let global = "global";

function outer() {
  let outerVar = "outer";

  function inner() {
    let innerVar = "inner";
    console.log(innerVar); // "inner"(当前作用域)
    console.log(outerVar); // "outer"(上层作用域)
    console.log(global); // "global"(全局作用域)
  }

  inner();
}

outer();

五、附加let、const、var区别

  1. let、const 声明的变量不存在声明提升。
  2. let、const 声明的变量不能重复声明。
  3. var 声明的全局变量会被挂载到 window上。
  4. const 声明的变量 值不能改。
相关推荐
天平35 分钟前
油猴脚本创建webworker踩坑记录
前端·javascript·typescript
原则猫2 小时前
前端基础大厦
前端
陈随易3 小时前
编程语言级别的Skill市场,AI Agent 的未来形态
前端·后端·程序员
SoaringHeart4 小时前
Flutter进阶:基于 EasyRefresh 的下拉刷新封装 n_easy_refresh_mixin.dart
前端·flutter
IT_陈寒6 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
子兮曰6 小时前
Agency-Agents 深度解析:400+ AI 专家的"梦之队"如何重塑开发工作流
前端·后端·vibecoding
竹林8187 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
妙码生花7 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
Awu12278 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude
咪库咪库咪8 小时前
Vue3-生命周期
前端