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 声明的变量 值不能改。
相关推荐
xinyu_Jina3 分钟前
PaperStudio:WYSIWYG文档的Web实现——从CSS Print到客户端PDF生成的技术解析
前端·css·pdf
默默学前端10 分钟前
html列表标签及css列表属性
前端·css·html5
天天扭码9 小时前
如何实现流式输出?一篇文章手把手教你!
前端·aigc·ai编程
前端 贾公子9 小时前
vue移动端适配方案 === postcss-px-to-viewport
前端·javascript·html
GISer_Jing11 小时前
AI营销增长:4大核心能力+前端落地指南
前端·javascript·人工智能
明远湖之鱼11 小时前
一种基于 Service Worker 的渐进式渲染方案的基本原理
前端
前端小端长12 小时前
Vue 中 keep-alive 组件的原理与实践详解
前端·vue.js·spring
FeelTouch Labs12 小时前
Nginx核心架构设计
运维·前端·nginx
雪球工程师团队12 小时前
别再“苦力”写后台,Spec Coding “跑” 起来
前端·ai编程