Webpack的构建流程

Webpack 的构建流程主要包括以下步骤:

初始化:启动构建,读取和合并配置参数,加载 Plugin,实例化 Compiler。
编译:从 Entry 出发,针对每个 Module 串行调用对应的 Loader 去翻译文件的内容,再找到该 Module 依赖的 Module,递归地进行编译处理。
输出:对编译后的 Module 进行深度优化,如模块合并、拆分等,然后将这些信息写入到 Chunk 中,再把 Chunk 转换成文件,输出到文件系统中。
以下是这个过程的伪代码:

// 初始化
const options = readAndMergeConfigOptions();
const compiler = new Compiler(options);

// 加载插件
for (const plugin of options.plugins) {
  plugin.apply(compiler);
}

// 编译
const context = { compiler, options };
for (const entry of options.entry) {
  compileModule(context, entry);
}

// 输出
const chunks = generateChunks(context);
for (const chunk of chunks) {
  emitFile(context, chunk);
}

这个过程中,Webpack 会广播出许多事件,插件可以监听这些事件,在适当的时机添加自己的逻辑。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值