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 声明的变量 值不能改。
相关推荐
景早10 分钟前
商品案例-组件封装(vue)
前端·javascript·vue.js
不说别的就是很菜27 分钟前
【前端面试】Vue篇
前端·vue.js·面试
IT_陈寒28 分钟前
Java 17实战:我从老旧Spring项目迁移中总结的7个关键避坑点
前端·人工智能·后端
倚肆42 分钟前
CSS 动画与变换属性详解
前端·css
blackorbird1 小时前
谷歌 Chrome 浏览器的指纹识别技术,一边反追踪一边搞追踪
前端·chrome
Mintopia1 小时前
🚀 共绩算力:3分钟拥有自己的图像优化服务-CodeFormer:先进的图像算法优化、修复马赛克、提升图片清晰度等
前端·人工智能·ai编程
Lhuu(重开版2 小时前
html语法
前端·html
月弦笙音2 小时前
【vue3】这些不常用的API,却很实用
前端·vue.js·面试