当前位置: 首页 > article >正文

技术长期主义:用本分思维重构JavaScript逆向知识体系(一)Babel、AST、ES6+、ES5、浏览器环境、Node.js环境的关系和处理流程

基础不牢,地动山摇,逆向越久,越发现基础的重要性,本系列,回顾js逆向基础,让自己的知识体系更加系统化。

以下是 Babel、AST、ES6+、ES5、浏览器环境、Node.js环境 的关系和流程的详细说明及图表:


一、核心关系图表

ES6+ 代码
Babel:解析,转换,生成
AST抽象语法树:语法树操作
ES5 代码:浏览器/Node.js兼容
Polyfill如 core-js
浏览器环境
Node.js环境

二、详细流程与关系说明

1. 开发阶段:ES6+ 代码
  • 目标:开发者编写现代 JavaScript(ES6+),使用新语法(如箭头函数、classasync/await)。
  • 问题:旧浏览器(如 IE)或低版本 Node.js 无法直接运行 ES6+ 代码。
2. 构建阶段:Babel 处理
  • 步骤 1:解析(Parsing)

    • 工具@babel/parser
    • 输入:ES6+ 代码字符串。
    • 输出:生成 AST(抽象语法树),结构化表示代码逻辑。
  • 步骤 2:转换(Transformation)

    • 工具@babel/traverse + 插件(如 @babel/preset-env
    • 操作:通过访问者模式遍历 AST,修改语法节点:
      • constvar
      • 将箭头函数 → 普通函数
      • class → 原型链函数
      • 其他语法降级(如解构赋值、模板字符串)。
  • 步骤 3:生成(Generation)

    • 工具@babel/generator
    • 输入:修改后的 AST。
    • 输出:生成 ES5 代码。
  • 步骤 4:Polyfill 注入

    • 工具core-js + regenerator-runtime
    • 作用:补充 ES5 中缺失的 API(如 PromiseArray.from)。
3. 运行阶段:目标环境
  • 浏览器环境

    • 输入:转换后的 ES5 代码 + Polyfill。
    • 兼容性:确保代码在旧浏览器(如 IE 11)中运行。
    • 注意:Polyfill 需通过 <script> 引入或打包工具注入。
  • Node.js 环境

    • 输入:转换后的 ES5 代码(可选 Polyfill)。
    • 兼容性:根据 Node.js 版本决定是否需要转换:
      • Node.js v12+ 支持大部分 ES6+ 语法,可减少转换。
      • 旧版本(如 Node.js v6)需完整转换。

三、关键组件交互关系

组件作用关联对象
ES6+ 代码开发者编写的现代 JavaScript 代码。Babel、AST
Babel编译器,负责将 ES6+ 转换为 ES5。AST、ES5 代码、Polyfill
AST代码的抽象语法树表示,Babel 操作的核心数据结构。Babel、ES6+、ES5
ES5 代码转换后的低版本代码,兼容旧环境。浏览器、Node.js
Polyfill补充 ES5 中缺失的 API(如 Promise)。浏览器、Node.js、Babel
浏览器环境运行转换后的 ES5 代码,依赖 Polyfill 支持新 API。ES5 代码、Polyfill
Node.js 环境运行转换后的 ES5 代码,根据版本选择是否需 Polyfill。ES5 代码、Polyfill(可选)

四、完整流程图

开发者编写 ES6+ 代码
Babel 解析代码为 AST
Babel 插件/Preset 转换 AST
Babel 生成 ES5 代码
注入 Polyfill如 core-js
浏览器环境:旧版浏览器执行 ES5 + Polyfill
Node.js环境:根据版本执行 ES5,可选 Polyfill

五、实际场景示例

场景 1:浏览器兼容 IE 11
  1. 编写 ES6+ 代码:
    const sum = (a, b) => a + b;
    
  2. Babel 转换为 ES5:
    var sum = function(a, b) { return a + b; };
    
  3. 注入 core-js Polyfill 补充 Promise 等 API。
  4. 浏览器加载 ES5 代码和 Polyfill。
场景 2:Node.js v14 项目
  1. 编写 ES6+ 代码(Node.js v14 原生支持 async/await)。
  2. Babel 仅转换不被支持的语法(如实验性装饰器)。
  3. 无需注入 Polyfill(Node.js v14 已内置大部分 ES6+ API)。

六、总结

  • Babel 是连接现代语法(ES6+)与旧环境(ES5)的桥梁。
  • AST 是 Babel 操作的核心,通过修改语法树实现代码转换。
  • Polyfill 解决 API 缺失问题,与语法转换互补。
  • 浏览器/Node.js 环境 决定最终代码的兼容性策略。
    ES6+(ECMAScript 2015及更高版本)与ES5(ECMAScript 5)是JavaScript语言的两个重要版本,以下是它们的核心区别及Babel转换的必要性:

七、其他问题

一、ES6+ 与 ES5 的核心区别
1. 变量声明
  • ES5:只有 var(函数作用域)
    var x = 10; // 变量提升,可重复声明
    
  • ES6+:引入 letconst(块级作用域)
    let y = 20; // 不可重复声明
    const PI = 3.14; // 常量
    
2. 箭头函数
  • ES6+ 简化函数语法,自动绑定 this
    const add = (a, b) => a + b; 
    
  • ES5 需用 function 显式定义:
    var add = function(a, b) { return a + b; };
    
3. 模板字符串
  • ES6+ 支持多行字符串和插值:
    const name = "Alice";
    console.log(`Hello, ${name}!`);
    
  • ES5 需手动拼接:
    console.log("Hello, " + name + "!");
    
4. 解构赋值
  • ES6+ 直接提取对象或数组的值:
    const [a, b] = [1, 2]; // 数组解构
    const { name, age } = user; // 对象解构
    
  • ES5 需逐个赋值。
5. 类与继承
  • ES6+ 提供 class 关键字:
    class Person {constructor(name) { this.name = name; }
    }
    
  • ES5 通过原型链实现:
    function Person(name) { this.name = name; }
    Person.prototype.sayHello = function() {};
    
6. 模块化
  • ES6+ 原生支持 import/export
    import React from 'react';
    export default function App() {}
    
  • ES5 使用 CommonJS 或 AMD:
    var React = require('react');
    module.exports = App;
    
7. 异步编程
  • ES6+ 引入 Promise(ES6)、async/await(ES2017):
    async function fetchData() {const res = await fetch(url);
    }
    
  • ES5 依赖回调函数,易导致“回调地狱”。
8. 新数据结构
  • ES6+ 新增 SetMapSymbol 等:
    const set = new Set([1, 2, 3]);
    const sym = Symbol('key');
    
9. 默认参数与剩余参数
  • ES6+ 支持默认值和不定参数:
    function greet(name = "Guest", ...args) {}
    
  • ES5 需手动判断参数是否存在。

二、为什么需要Babel?

  • 浏览器兼容性:旧版浏览器(如IE)不支持ES6+语法。
  • 转换过程:Babel将ES6+代码转换为ES5,确保跨浏览器兼容。

三、使用Babel的步骤

1. 安装依赖
npm install @babel/core @babel/cli @babel/preset-env --save-dev
2. 创建配置文件 .babelrc
{"presets": ["@babel/preset-env"]
}
3. 转换代码
npx babel src -d dist
4. 处理Polyfill(补充缺失API)

安装Polyfill库:

npm install core-js regenerator-runtime

在入口文件顶部引入:

import "core-js/stable";
import "regenerator-runtime/runtime";

四、ES6+代码转换为ES5转换示例

  • ES6+代码
    const greet = (name = "Guest") => `Hello, ${name}!`;
    
  • Babel转换后的ES5代码
    "use strict";
    var greet = function greet() {var name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "Guest";return "Hello, " + name + "!";
    };
    

五、Babel 是什么?

Babel 是一个 JavaScript 编译器,核心功能是将 ES6+ 代码 转换为 向后兼容的 ES5 代码,使开发者能使用最新语法特性,同时保证代码在旧浏览器中运行。
除了语法转换,Babel 还可用于:

  • 代码压缩(如移除注释、缩短变量名)
  • 代码静态分析(如 ESLint 的语法检查)
  • Polyfill 注入(补充缺失的 API,如 Promise
  • 框架语法支持(如 React 的 JSX 转换)

六、AST 是什么?

抽象语法树(Abstract Syntax Tree, AST) 是代码的 结构化表示,将代码解析为树状数据结构,便于程序分析或修改。
例如,代码 const sum = (a, b) => a + b; 对应的 AST 可能如下:

{"type": "VariableDeclaration","declarations": [{"type": "VariableDeclarator","id": { "type": "Identifier", "name": "sum" },"init": {"type": "ArrowFunctionExpression","params": [{ "type": "Identifier", "name": "a" },{ "type": "Identifier", "name": "b" }],"body": {"type": "BinaryExpression","operator": "+","left": { "type": "Identifier", "name": "a" },"right": { "type": "Identifier", "name": "b" }}}}],"kind": "const"
}

七、Babel 如何处理 AST?

Babel 的工作流程分为三个阶段,均围绕 AST 展开:

1. 解析(Parsing)
  • 输入:源代码字符串(如 ES6+)
  • 输出:AST
  • 工具@babel/parser(基于 Acorn)
  • 过程:词法分析(生成 Token 流) → 语法分析(构建 AST)
2. 转换(Transformation)
  • 输入:原始 AST
  • 输出:修改后的 AST
  • 工具@babel/traverse(遍历 AST)、插件(修改 AST)
  • 核心机制访问者模式(Visitor Pattern)
    • 定义一组方法(如 Identifier(), ArrowFunctionExpression()),在遍历 AST 时匹配节点类型并执行操作。
    • 示例:将箭头函数转换为普通函数:
      const visitor = {ArrowFunctionExpression(path) {// 替换箭头函数节点为 function 表达式path.replaceWith(/* 新的 AST 节点 */);}
      };
      
3. 生成(Generation)
  • 输入:修改后的 AST
  • 输出:目标代码(如 ES5)
  • 工具@babel/generator

八、Babel 插件与 AST 操作示例

Babel 的转换能力通过 插件(Plugin) 实现,插件本质是操作 AST 的函数。以下是一个简单示例:

目标:将 const 转换为 var
步骤
  1. 创建插件
    export default function () {return {visitor: {VariableDeclaration(path) {if (path.node.kind === "const") {path.node.kind = "var"; // 直接修改节点属性}}}};
    }
    
  2. 配置 Babel.babelrc):
    {"plugins": ["./custom-plugin.js"]
    }
    
  3. 转换结果
    • 输入:const x = 10;
    • 输出:var x = 10;

九、AST 操作的实际应用场景

  1. 语法降级

    • class 转换为 function + 原型链。
    • () => {} 转换为 function() {},并处理 this 绑定。
  2. 代码优化

    • 删除未使用的变量(Tree Shaking)。
    • 预计算常量表达式(如 2 * 36)。
  3. 自定义语法扩展

    • 支持 JSX、Vue 模板等非标准语法。
    • 实现实验性语法(如管道操作符 |>)。
  4. 静态分析

    • 类型检查(如 TypeScript 类型擦除)。
    • 代码复杂度检测(如循环嵌套深度)。

十、AST 可视化工具

若需直观查看代码的 AST 结构,可使用以下工具:

  • AST Explorer:在线实时生成 AST,支持 Babel、TypeScript 等解析器。
  • Babel REPL:直接查看 Babel 转换前后的代码及中间 AST。

总结

Babel 通过将代码解析为 AST,在语法树层面进行修改,最终生成目标代码。AST 是编译器的通用中间表示形式,Babel 的插件机制赋予开发者直接操作 AST 的能力,使其成为前端工程化的核心工具之一。理解 AST 的操作原理,是编写自定义 Babel 插件、优化构建流程的关键。ES6+通过新语法和特性大幅提升开发效率,而Babel负责将现代代码转换为广泛兼容的ES5,平衡了开发体验与浏览器兼容性。

相关文章:

技术长期主义:用本分思维重构JavaScript逆向知识体系(一)Babel、AST、ES6+、ES5、浏览器环境、Node.js环境的关系和处理流程

基础不牢&#xff0c;地动山摇&#xff0c;逆向越久&#xff0c;越发现基础的重要性&#xff0c;本系列&#xff0c;回顾js逆向基础&#xff0c;让自己的知识体系更加系统化。 以下是 Babel、AST、ES6、ES5、浏览器环境、Node.js环境 的关系和流程的详细说明及图表&#xff1a;…...

Oracle 数据库系统全面详解

Oracle 数据库是全球领先的关系型数据库管理系统(RDBMS)&#xff0c;由 Oracle 公司开发。它为企业级应用提供了高性能、高可用性、安全性和可扩展性的数据管理解决方案。 目录 一、Oracle 数据库体系结构 1. 物理存储结构 主要组件&#xff1a; 存储层次&#xff1a; 2. …...

LeetCode 解题思路 29(Hot 100)

解题思路&#xff1a; 映射关系建立&#xff1a;创建一个哈希表存储数字到字母的映射。递归参数&#xff1a; 给定字符串 digits、结果集 result、当前路径 path、当前位置 start。递归过程&#xff1a; 当当前位置 start 等于 digits 长度时&#xff0c;说明已经遍历完 digi…...

使用Python解析PPT文件并生成JSON结构详解

引言 PowerPoint&#xff08;PPT&#xff09;文件的自动化处理是办公自动化和数据提取的常见需求。本文将介绍如何通过Python的python-pptx库&#xff0c;将PPT文件的样式、结构、文本内容等信息解析为标准化的JSON格式&#xff0c;为后续的自动化处理、数据迁移或样式复用提供…...

LabVIEW永磁同步电机性能测试系统

开发了一种基于LabVIEW的永磁同步电机&#xff08;PMSM&#xff09;性能测试系统的设计及应用。该系统针对新能源汽车使用的电机进行稳态性能测试&#xff0c;解决了传统测试方法成本高、效率低的问题&#xff0c;实现了测试自动化&#xff0c;提高了数据的准确性和客观性。 ​…...

MTK Camera 照片切视频Systrace拆解分析

和你一起终身学习&#xff0c;这里是程序员Android 经典好文推荐&#xff0c;通过阅读本文&#xff0c;您将收获以下知识点: 一、Systrace 拆解概览二、Systrace 阶段拆解详解 一、Systrace 拆解概览 MTK Camera 照片切换视频trace 拆解(非切换摄像头类) 照片切换视频模块trace…...

某合约任意提取BNB漏洞

1背景描述 合约是一个在满足特定条件时在区块链上执行代码的程序&#xff0c;各方以数字签署合同的方式准许并维护它的其运行。这些代码可以是向朋友汇款、买卖 NFT 虚拟商品等一系列复杂的内容。 存在漏洞的目标合约是一个结合Meme文化病毒式传播与去中心化金融&#xff08;D…...

Linux_3.2

今天继续学习shell语法 shell类似一个面向过程的语言,要区分好面向过程和面向对象的语言的区别。 循环语句 for循环 for i in a 2 cc doecho $i done #输出a 2 ccfor file in `ls` doecho $file done #输出ls命令的输出for i in $(seq 1 10) doecho $i done #输出1-10,seq…...

插件实现:分别通过winform和WPF界面输入操作CAD——CAD c#二次开发

效果如下图所示&#xff1a; 主程序 using Autodesk.AutoCAD.ApplicationServices; using Autodesk.AutoCAD.DatabaseServices; using Autodesk.AutoCAD.EditorInput; using Autodesk.AutoCAD.Geometry; using Autodesk.AutoCAD.Runtime; using System; using System.Windows…...

【学Rust写CAD】20 平铺模式结构体(spread.rs)

这个 Spread。rs文件定义了渐变超出定义区域时的扩展方式&#xff0c;通常用于处理渐变在边界之外的行为。 源码 //color/spread.rs #[derive(Debug, Clone, Copy)] pub struct Pad; // 空结构体&#xff0c;表示 Pad 模式#[derive(Debug, Clone, Copy)] pub struct Reflect…...

maya调整全局关节显示大小

请按以下步骤操作&#xff1a; 在 Maya 主菜单栏中&#xff0c;找到 Display (显示) 菜单。 在 Display 菜单下&#xff0c;找到 Animation (动画) 子菜单。 在 Animation 子菜单中&#xff0c;点击 Joint Size... (关节大小...)。 这时会弹出一个小窗口或者直接在界面上出现…...

白酒迈入3.0时代,珍酒李渡如何穿越周期高质增长?

当下&#xff0c;白酒行业仍处深度调整期&#xff0c;过往通过渠道拓展、硬广宣传等推动规模扩张、提升市场份额的模式&#xff0c;愈发难以为继。 行业迫切需要构建高质增长新模式&#xff0c;完成增长动能转换。中国酒业协会理事长宋书玉提出&#xff0c;白酒消费亟需进入品…...

HTTP代理:网页加速的隐形引擎

目录 引言&#xff1a;网页加载速度为何至关重要&#xff1f; 一、HTTP代理的核心加速原理 二、四大加速黑科技详解 三、实战场景性能对比 四、代理加速的隐藏代价 五、未来发展趋势 结语&#xff1a;智能代理的选型指南 引言&#xff1a;网页加载速度为何至关重要&#…...

人工智能-LangGraph+ChatUI+DeepSeek API搭建本地智能助手

人工智能-LangGraphChatUIDeepSeek API搭建本地智能助手 0 环境说明1 LangGraph2 Agent Chat UI 0 环境说明 环境项环境说明操作系统Windows11 专业版硬件信息联想拯救者Y9000PcondaAnancondaPython版本3.12NodeJs18.20.0 # 使用conda创建python环境 conda create -n langgra…...

3dmax批量转glb/gltf/fbx/osgb/stl/3ds/dae/obj/skp格式导出转换插件,无需一个个打开max,材质贴图在

3dmax批量转glb/gltf/fbx/osgb/stl/3ds/dae/obj/skp格式导出转换插件&#xff0c;无需一个个打开max&#xff0c;材质贴图在 3dmax批量转glb/gltf/fbx/osgb/stl/3ds/dae/obj/skp格式导出转换插件&#xff0c;无需一个个打开max&#xff0c;材质贴图在...

虚幻5入门

常用操作 运行时&#xff0c;调试相机&#xff0c;按~键&#xff0c;输入ToggleDebugCamera 。进入自由视角 常用节点 gate节点&#xff1a;用于控制该流程通不通&#xff0c;执不执行。Flip Flop节点&#xff1a;反转执行&#xff0c;一次A&#xff0c;一次B。Set Timer by…...

【解决】Edge浏览器硬件加速问题:无法滚动与卡顿的应对方法

Edge浏览器开启硬件加速后无法滚动屏幕&#xff0c;关闭后虽然可以滚动但出现卡顿&#xff0c;可能是由多种原因导致的。以下是一些可能的解决方法&#xff1a; 1. 检查显卡驱动 更新显卡驱动&#xff1a;确保显卡驱动是最新版本。过时的驱动可能会导致硬件加速功能不稳定。回…...

慧通测控:汽车RGB氛围灯功能测试介绍

在汽车内饰不断进化的当下&#xff0c;汽车 RGB 氛围灯已从曾经的小众配置&#xff0c;逐渐成为众多车主提升驾乘体验的热门选择。它宛如车内的 “魔法精灵”&#xff0c;凭借丰富的功能&#xff0c;为单调的车厢披上一层梦幻而温馨的色彩。今天&#xff0c;让我们深入探究汽车…...

QML Book 学习基础6(定位/布局元素)

目录 定位元素 Column Row Grid Flow 布局元素 1.元素填充它的⽗元素。 2.对齐 定位元素 Column Column &#xff08;列&#xff09;元素将它的⼦对象通过顶部对⻬的列⽅式进⾏排列。 spacing 属性⽤来设置每个元素之间的间隔⼤⼩ Row Row &#xff08;⾏&#xff09;元…...

【SpringCloud】LoadBalance-负载均衡

4. 负载均衡-LoadBalance 4.1 为什么需要负载均衡&#xff1f; 不知道各位心中有没有女神&#xff0c;通常来说一个女神就会有多个舔狗&#xff0c;那这些舔狗呢&#xff0c;就会心甘情愿的帮女神干活&#xff0c;假设女神小美现在有三个舔狗&#xff0c;小美喜欢让这三个舔狗…...

自然语言处理(26:(终章Attention 2.)带Attention的seq2seq的实现)

系列文章目录 终章 1&#xff1a;Attention的结构 终章 2&#xff1a;带Attention的seq2seq的实现 终章 3&#xff1a;Attention的评价 终章 4&#xff1a;关于Attention的其他话题 终章 5&#xff1a;Attention的应用 目录 系列文章目录 前言 一、编码器的实现 二、解…...

Sentinel实战(二)、流控规则之流控阈值类型、流控模式

spring cloud Alibaba-sentinel-流控 流控规则前置环境一、基于阈值类型(QPS/线程数)维度,设置流控规则demo1、流控规则:设置QPS流控规则设置含义测试,观察流控规则设定后的效果demo2、流控规则-设置线程数流控规则设置含义测试,观察流控规则设定后的效果二、基于流控模…...

AI与.NET技术实操系列(四):使用 Semantic Kernel 和 DeepSeek 构建AI应用

1. 引言 在人工智能技术飞速发展的今天&#xff0c;大型语言模型&#xff08;Large Language Models, LLMs&#xff09;已成为智能应用开发的核心驱动力。从智能客服到自动化内容生成&#xff0c;LLMs的应用正在深刻改变我们的工作和生活方式。 对于.NET开发者而言&#xff0c;…...

go 使用os复制文件

在 Go 语言中&#xff0c;你可以使用 os 包中的 Open、Create、Copy 函数来复制文件。以下是一个简单的示例&#xff1a; package mainimport ("fmt""io""os" )func copyFile(src, dst string) error {// 打开源文件srcFile, err : os.Open(src…...

嵌入式软件安全设计指南(V2.0)

嵌入式软件安全设计指南&#xff08;V2.0&#xff09; 一、安全设计基础原则 1.1 最小特权原则 /* FreeRTOS任务权限控制示例 */ void vTaskSafe(void *pvParameters) {// 限制IO访问权限vTaskRestrictPermissions(portPRIVILEGED_BIT);// 仅允许访问指定内存区域vTaskSetMP…...

HarmonyOS:ComposeTitleBar 组件自学指南

在日常的鸿蒙应用开发工作中&#xff0c;我们常常会面临构建美观且功能实用的用户界面的挑战。而标题栏作为应用界面的重要组成部分&#xff0c;它不仅承载着展示页面关键信息的重任&#xff0c;还能为用户提供便捷的操作入口。最近在参与的一个项目里&#xff0c;我就深深体会…...

25-智慧旅游系统(协同算法)三端

介绍 技术&#xff1a; 基于 B/S 架构 SpringBootMySQLLayuivue 环境&#xff1a; Idea mysql maven jdk1.8 node 管理端功能 首页展示图表&#xff1a;以数据可视化方式展示关键业务数据。 用户管理&#xff1a;管理系统用户&#xff0c;包括查看、编辑等操作。 供应商管…...

数据结构实验1.2: 顺序表的基本运算

文章目录 一&#xff0c;问题描述二&#xff0c;基本要求三&#xff0c;算法分析&#xff08;1&#xff09;插入算法&#xff08;2&#xff09;删除算法 四&#xff0c;参考程序五&#xff0c;运行效果 一&#xff0c;问题描述 创建一个顺序表&#xff0c;编程实现顺序表的下列…...

Swoole 的 Hyperf 框架和 Go 的 Gin 框架高并发原理以及技术实现对比分析

Swoole 的 Hyperf 框架和 Go 的 Gin 框架虽然都支持高并发&#xff0c;但它们的实现原理、底层机制和适用场景有显著差异。以下从 高并发原理、技术实现区别、优缺点 三个方面详细分析&#xff1a; 一、高并发实现原理 1. Hyperf (PHP Swoole) Hyperf 的高并发能力基于 Swoo…...

【QT】QT中的信号与槽

QT中的信号与槽 一、信号与槽函数的作用二、如何关联信号与槽函数1、借助集成开发环境&#xff0c;右键转到槽函数示例代码&#xff1a; 2、调用connect函数手动关联信号与槽函数 三、扩展四、总结信号与槽的特点1、一个类如果要使用信号以及槽函数&#xff0c;那么该类的定义中…...