最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 掌握源码阅读的技巧 - Webpack 篇

    正文概述 掘金(方应杭)   2021-03-23   563

    高级前端面试中经常有这么几道题:

    1. 说一说 loader和 plugin 的区别
    2. webpack 构建流程是怎样的
    3. 编写 webpack loader 的思路
    4. 编写 webpack plugin 的思路

    网上能搜到一些答案,但是这些答案我一一看过了,要么过于肤浅留于表面,要么冗长繁杂难以卒读。

    如果面试岗位的工资是 20k 以上,面试官必定会追问到更深层次。

    因此,我花了一个星期把 Webpack 5 的源码逐行扫了一遍,理出了主要脉络。整个阅读过程我录制成了视频,总时长不到 3 小时,但把 Webpack 的整体架构、打包思路、loader 实现思路、plugin 实现思路、parser 运行流程等都讲到了,最重要的是,通过视频你会掌握「阅读源码的技巧」。

    接下来是文字教程:


    掌握源码阅读的技巧 - Webpack 篇

    webpack-cli 是如何调用 wepack 的

    webpack = require('webpack')
    compiler = webpack(options, callback)
    

    hooks.xxx.call 是什么

    Tapable 是 webpack 团队为了写 Webpack 而写的一个事件/钩子库

    用法

    定义一个事件/钩子
    this.hooks.eventName = new SyncHook(["arg1", "arg2"]);
    监听一个事件/钩子
    this.hooks.eventName.tap('监听理由', fn)
    触发一个事件/钩子
    this.hooks.eventName.call('arg1', 'arg2')
    

    Webpack 的整体流程是怎样的

    至少有 env init run beforeCompile compile compilation make finishMake seal optimize afterCompile emit 等钩子

    读取 index.js 并分析和收集依赖是在哪个阶段?

    make - finishMake 阶段

    make - finishMake 之间,做了什么

    • 搜索 make.tap,发现很多地方监听了 make 事件
    • 凭借我们的直觉,我们直接打开 EntryPlugin
    • EntryPlugin 的 addEntry 函数就是 make 阶段最重要的事情之一

    factory.create 中的 factory 是什么东西?

    是从 factorizeModule(options 的 options.factory 来的。

    是从 moduleFactory 来的。

    是用 this.dependencyFactories.get(Dep) 得到的。

    你搜 compilation.tap 就知道,它是 normalModuleFactory,简称 nmf

    我把所有钩子都搜了,搜了半个小时,能不知道吗?

    结论:factory 就是 nmf,所以 factory.create 就是 nmf.craete

    nmf.create 做了什么?

    • nmf.create 得到了一个 module 对象
    • 后续操作是 addModule 和 buildModule

    addModule 做了什么?

    • 跟前面课程的思路类似,把 module 添加到 compilation.modules 里
    • 而且还通过检查 id 防止重复添加

    buildModule 做了什么?

    • 看名字就知道是重要操作,它调用了 module.build()
    • 来到 NormalModule.js 看 build 源码,发现了 runLoaders
    • 然后来到 processResult(),发现了 _source = ... 和 _ast = null
    • 这是要做什么?显然是要把 _source 变成 _ast 了!
    • 来到 doBuild 的回调,发现了 this.parser.parse() !
    • parse 就是把 code 变成 ast
    • 问题来了,parser 是什么,parse() 的源码在哪?
    • 继续跟代码会发现 parser 来自于 acorn 库,需要编译原理知识,不跟进了
    • 如果你想要学习编译原理知识,可以购买我的科班课程

    Webpack 如何知道 index.js 依赖了哪些文件

    • blockPreWalkStatement() 对 ImportDeclaration 进行了检查
    • 一旦发现 import 'xxx',就会触发钩子,对应的监听函数会处理依赖
    • 其中 walkStatements() 对 ImportExpression 进行了检查
    • 一旦发现 import('xxx'),就会触发钩子,对应的监听函数也会处理依赖
    • 这里不讨论 require,大家有兴趣可以自己研究

    Webpack 是怎么把 modules 合并成一个文件的?

    • 看 compilation.seal(),该函数会创建 chunks、 为每个 chunk 进行 codeGeneration,然后为每个 chunk 创建 asset
    • seal() 之后,emitAssets()、emitFiles() 会创建文件(emit 就是射)
    • 最终得到 dist/main.js 和其他 chunk 文件

    今年,我将研读更多前端项目源码并做成新的视频课程,敬请期待。

    如果有什么开源项目的源码是你想了解的,欢迎留言。

    完。


    起源地下载网 » 掌握源码阅读的技巧 - Webpack 篇

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元