【Webpack】生命周期

概述

Webpack 的生命周期是指从启动到结束整个过程中会经历的一系列步骤。简单来说,Webpack 的生命周期分为以下几个主要阶段:

1)初始化:Webpack 读取配置文件,初始化参数。

2)编译:根据入口文件,递归地构建依赖图。

3)模块解析与转换:模块被解析、编译和转换成标准模块。

4)优化:在生成块和模块之后,对依赖关系进行优化。

5)生成:根据最终的依赖关系,生成最终的输出文件。

扩展

1)初始化:

  • Webpack 从配置文件中读取配置,初始化编译器 (Compiler) 对象。
  • 初始化之后,调用所有配置的插件的 apply 方法,附上 Compiler 实例。
  • 根据配置文件中的 entry,确定构建的入口文件。

2)编译:

  • 从入口文件开始,调用对应的 loader 进行处理。
  • 递归地解析入口文件中依赖的模块,同样应用相应的 loader。
  • 构建依赖图(Dependency Graph),其中每个模块都是节点。

3)模块解析与转换:

  • Webpack 内部使用 acornesprima 等工具对模块进行解析。
  • loader 将特定类型的文件(如 TypeScript、Sass)转换成 JavaScript 模块。
  • 在此过程中,如果遇到动态导入等需要进一步解析的模块,会继续处理。

4)优化:

  • 此阶段进行模块优化,包括 Tree-Shaking、Scope Hoisting 等。
  • 优化图形中模块的依赖关系,消除冗余代码。

5)生成:

  • 根据优化后的依赖关系图,生成块(Chunk)。
  • 最后将这些块输出到配置好的输出目录,每个块即为最终生成的文件(如 bundle.js)。

插件在不同的生命周期钩子中插入代码,例如:compiler.hooks.run.tap 可以在编译开始时执行,compilation.hooks.optimize 可以优化模块。通过这些钩子,能够更灵活地控制 Webpack 的行为。

相关推荐
Wect36 分钟前
React 性能优化精讲
前端·react.js·性能优化
追风筝的人er1 小时前
SpringBoot+Vue3 企业考勤如何处理法定假期?节假日方案、调休补班与工作日判断链路拆解
前端·vue.js·后端
无敌的黑星星1 小时前
Java8 CompletableFuture 实战指南
linux·前端·python
雁鸣零落2 小时前
如何在 Chrome 中查看其他浏览器的书签?书签空间订阅与侧边栏只读切换指南
前端·chrome·edge浏览器
hpoenixf2 小时前
一天上线 + 零返工:我如何给复杂前端需求建立“安全感”
前端
广州华水科技3 小时前
单北斗GNSS变形监测系统在水利工程安全保障中的应用与优势分析
前端
yqcoder3 小时前
CSS 外边距重叠(Margin Collapsing):现象、原理与完美解决方案
前端·css
山楂树の4 小时前
图像标注大坑:img图片 + Canvas 叠加标注,同步放大后标注位置偏移、对不齐?详解修复方案及亚像素处理原理
前端·css·学习·canva可画
本山德彪4 小时前
我做了一个拼豆图纸生成器,把照片秒变图纸
前端
DTrader4 小时前
用TS无法实盘量化? - 实盘均线策略
前端·api