美文网首页
5.2 流程细节

5.2 流程细节

作者: 柠檬与断章 | 来源:发表于2019-11-21 14:07 被阅读0次

5.2 流程细节

问题一: 流程细节?

Webpack 的构建流程可以分为以下三大阶段:

  1. 初始化:启动构建,读取与合并配置参数,加载 Plugin,实例化 Compiler。
  2. 编译:从 Entry 发出,针对每个 Module 串行调用对应的 Loader 去翻译文件内容,再找到该 Module 依赖的 Module,递归地进行编译处理。
  3. 输出:对编译后的 Module 组合成 Chunk,把 Chunk 转换成文件,输出到文件系统。

如果只执行一次构建,以上阶段将会按照顺序各执行一次。但在开启监听模式下,流程将变为如下:

![image](https://img.haomeiwen.com/i1755473/03b2cd17d001864a.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

在每个大阶段中又会发生很多事件,Webpack 会把这些事件广播出来供给 Plugin 使用,下面来一一介绍。

初始化阶段

事件名 解释
初始化参数 从配置文件和 Shell 语句中读取与合并参数,得出最终的参数。 这个过程中还会执行配置文件中的插件实例化语句new Plugin()
实例化 Compiler 用上一步得到的参数初始化 Compiler 实例,Compiler 负责文件监听和启动编译。Compiler 实例中包含了完整的 Webpack 配置,全局只有一个 Compiler 实例。
加载插件 依次调用插件的 apply 方法,让插件可以监听后续的所有事件节点。同时给插件传入 compiler 实例的引用,以方便插件通过 compiler 调用 Webpack 提供的 API。
environment 开始应用 Node.js 风格的文件系统到 compiler 对象,以方便后续的文件寻找和读取。
entry-option 读取配置的 Entrys,为每个 Entry 实例化一个对应的 EntryPlugin,为后面该 Entry 的递归解析工作做准备。
after-plugins 调用完所有内置的和配置的插件的 apply 方法。
after-resolvers 根据配置初始化完 resolver,resolver 负责在文件系统中寻找指定路径的文件。

编译阶段

事件名 解释
run 启动一次新的编译。
watch-run 和 run 类似,区别在于它是在监听模式下启动的编译,在这个事件中可以获取到是哪些文件发生了变化导致重新启动一次新的编译。
compile 该事件是为了告诉插件一次新的编译将要启动,同时会给插件带上 compiler 对象。
compilation 当 Webpack 以开发模式运行时,每当检测到文件变化,一次新的 Compilation 将被创建。一个 Compilation 对象包含了当前的模块资源、编译生成资源、变化的文件等。Compilation 对象也提供了很多事件回调供插件做扩展。
make 一个新的 Compilation 创建完毕,即将从 Entry 开始读取文件,根据文件类型和配置的 Loader 对文件进行编译,编译完后再找出该文件依赖的文件,递归的编译和解析。
after-compile 一次 Compilation 执行完成。
invalid 当遇到文件不存在、文件编译错误等异常时会触发该事件,该事件不会导致 Webpack 退出。

在编译阶段中,最重要的要数 compilation 事件了,因为在 compilation 阶段调用了 Loader 完成了每个模块的转换操作,在 compilation 阶段又包括很多小的事件,它们分别是:

事件名 解释
build-module 使用对应的 Loader 去转换一个模块。
normal-module-loader 在用 Loader 对一个模块转换完后,使用 acorn 解析转换后的内容,输出对应的抽象语法树(AST),以方便 Webpack 后面对代码的分析。
program 从配置的入口模块开始,分析其 AST,当遇到require等导入其它模块语句时,便将其加入到依赖的模块列表,同时对新找出的依赖模块递归分析,最终搞清所有模块的依赖关系。
seal 所有模块及其依赖的模块都通过 Loader 转换完成后,根据依赖关系开始生成 Chunk。

输出阶段

事件名 解释
should-emit 所有需要输出的文件已经生成好,询问插件哪些文件需要输出,哪些不需要。
emit 确定好要输出哪些文件后,执行文件输出,可以在这里获取和修改输出内容。
after-emit 文件输出完毕。
done 成功完成一次完成的编译和输出流程。
failed 如果在编译和输出流程中遇到异常导致 Webpack 退出时,就会直接跳转到本步骤,插件可以在本事件中获取到具体的错误原因。

在输出阶段已经得到了各个模块经过转换后的结果和其依赖关系,并且把相关模块组合在一起形成一个个 Chunk。 在输出阶段会根据 Chunk 的类型,使用对应的模版生成最终要要输出的文件内容。

相关文章

  • 5.2 流程细节

    5.2 流程细节 问题一: 流程细节? Webpack 的构建流程可以分为以下三大阶段: 初始化:启动构建,读取与...

  • 5. falcon-hbs模块

    5.1 介绍 5.2 安装Installation 5.3 配置 Configuration 5.4 执行流程 5...

  • 动能教育学习分享

    欧爸在5.2-5.3两天父亲教育节的课程笔记,满满的干货。 5.2 上午 关键词“主持” 主持就是围绕目标设计流程...

  • Spring boot | 启动分析

    spring 注解解析流程回顾 基本流程与3.1.x中基本一致,5.2.x版本在注解解析的时候 ,在加入到注册中心...

  • 当天流程&细节

    【全局时间管理人员】 负责提醒每一个时间点干什么,移动的闹钟。 (安排一个人) =================...

  • 10 C数组的使用

    1、why数组? 2、数组初始化 3、数组遍历 4、存储细节 5、使用中的注意点 5.1、基本注意点 5.2、和函...

  • 5.2 原型设计 - 原型设计流程

    ​激动人心的画原型环节来咯,不过呢,原型绘制没有太多的介绍,因为这已经相当于是结果产出了,从前面的需求分析、流程梳...

  • 周一实拍:誉丰林红木平面板组装流程和细节

    誉丰林红木平面板组装流程和细节

  • 郑少文2018-07-27周报

    本周工作内容 下周工作计划 达芬奇架构整体流程学习:包括开发流程,测试发布流程,上线流程各阶段细节需要熟练掌握接手...

  • 2016-06-23郴州桂阳县科目二失败总结

    1、整体细节流程不清晰 2、紧张 3、技术还不行科目二流程图

网友评论

      本文标题:5.2 流程细节

      本文链接:https://www.haomeiwen.com/subject/htmxictx.html