webpack中的Loader在编译过程中是如何应用的,最终输出的打包内容在什么位置

本文深入探讨了webpack中Loader的工作原理,详细解释了从EntryPlugin处理入口文件,到调用runLoaders运行Loader的过程。通过分析钩子机制,揭示了Webpack如何在编译过程中串联不同环节,并在构建完成后输出打包内容。重点关注了processResource步骤,它是读取和处理资源的关键环节。
摘要由CSDN通过智能技术生成

按照顺序提取其中一部分关键的环节。如下图:

在这里插入图片描述
首先要注意的是this.hook.make.callAsyncthis.hook.make.tapAsync 这种用法几乎涉及到webpack的各个部分,它使用钩子来串联业务的不同环节。

在上图中对于每个方法所在的文件路径都进行了标注,它的具体位置是工程根目录下的node_modules文件夹。这里所提取的环节全部都是webpack下的,需要注意的是,它在过程中还会涉及到其他的模块。比如 tapablewebpack-sourcewebpack-clistyle-loadercss-loader等。

Compiler.js中可以看到 this.hooks.make 对应的是:
在这里插入图片描述
对于钩子的用法在前面tapable的文章中介绍过。简单理解为它是一种事件监听的消息机制。tap是订阅者,而call是监听者。监听者监听消息,发布给订阅者。所以执行到 this.hook.make.callAsync的时候,它会调用 this.hook.make.tapAsync的回调函数。这里需要强调的时,callAsync 执行的是 tapAsync的回调。所以&#x

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

问问计算机

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值