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 声明的变量 值不能改。
相关推荐
灵感__idea3 小时前
Hello 算法:贪心的世界
前端·javascript·算法
GreenTea5 小时前
一文搞懂Harness Engineering与Meta-Harness
前端·人工智能·后端
killerbasd6 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
吴声子夜歌7 小时前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈7 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫7 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝7 小时前
svg图片
前端·css·学习·html·css3
王夏奇7 小时前
python中的__all__ 具体用法
java·前端·python
大家的林语冰8 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js
jiayong238 小时前
第 8 课:开始引入组合式函数
前端·javascript·学习