只用90行代码实现模块打包器

大家好,只用我卡颂。行代现模
今天来聊聊如何用90行代码实现一个现代JS模块打包器。码实
我们的块打打包器虽然迷你,但是包器实现了webpack的核心功能。
而且,只用我知道你看到大段代码头疼,行代现模所以这篇文章都是码实图。看完感兴趣的块打话,这里是包器完整代码的仓库地址[1],只有90行代码哦。只用
让我们愉快的行代现模开始吧。
生成依赖图
如果应用是码实个毛线团的话,那么入口文件就是块打线头。打包器要做的包器第一件事是:
顺着线头开始滤清整条线的走向

假设入口文件是entry.js:
// entry.js import a from ./a.js; import b from ./b.js; console.log(a, b);他依赖了a.js与b.js。

em... 有点太简陋了,让我们再扩展下a.js与b.js:
// a.js import c from ./c.js; // ... // b.js import d from ./d.js; import e from ./e.js; // ...所以整个依赖关系是这样:

打包器会从入口文件开始,尝试建立模块(即js文件)间的IT技术网依赖关系,也就是刚才我们讲的「顺着线头开始滤清整条线的走向」。
模块间的依赖关系可以通过分析模块代码中的import 声明语句得知。
为了能分析import 声明语句,可以使用babel等编译工具将模块代码分解为AST(抽象语法树)。
遍历AST,类型为ImportDeclaration的节点就是import声明语句。
最后,我们将AST重新转换为可执行的目标代码,可能还需要根据代码要执行的宿主环境(一般为浏览器)对代码做一些转换。
比如,浏览器不支持import ./a.js这样的ESM语法,那么我们需要将所有ESM语法转为CJS语法。
// 源代码 import ./a.js; // 转换后 require(./a.js);所以,对于任一模块(js文件),会经历:

右边包含目标代码和模块间依赖关系的数据结构被称为asset。
每个asset可以通过模块间依赖关系找到依赖的模块,重复这一过程,生成新的asset,最终形成整个应用所有asset间的源码下载依赖关系:

应用完整的依赖关系被称为「依赖图」(dependency graph)。
打包代码
接下来,只需要遍历「依赖图」,将所有asset的目标代码打包在一起就行。
所有代码会被打包在一个「立即执行函数」中:
(function(modules) { // 打包好的代码 })(modules)modules中保存了所有asset及他们之间的依赖关系。
如果你对modules的细节感兴趣,可以去文末仓库里翻代码
刚才说过,asset的目标代码是CJS规范的,类似:
// entry.js require(./a.js); require(./b.js);这意味着我们需要实现:
require方法(用于引入依赖的其他asset的目标代码) module对象(用于保存当前asset的目标代码执行后导出的数据)同时,为了防止不同asset的目标代码中的变量互相污染,每个目标代码需要独立的作用域。
我们将目标代码包裹在函数中:
// 我们操作的是字符串模版 `function (require, module, exports) { ${asset.code} }`所以,最终打包的结果为:
(function(modules) { function require() {// ...} require(入口asset的ID) })(modules)这段字符串被包裹在浏览器
这段字符串被包裹在浏览器<script>标签内,会依次执行:
require(入口asset的b2b信息网ID),执行入口asset的目标代码 目标代码内部会调用require执行其他asset的目标代码 一步步执行下去...总结
打包器的工作原理分为两步:
从入口文件开始遍历,生成「依赖图」 根据依赖图,将代码打包进一个「立即执行函数」这个打包器还很稚嫩,缺失很多必要的功能,比如:
解决循环依赖 缓存但是瑕不掩瑜嘛~
参考资料
[1]完整代码的仓库地址: https://github.com/BetaSu/minipack
相关文章
世界最佳杀毒软件是什么?(揭秘最强大的杀毒软件,保护你的计算机安全!)
摘要:在互联网时代,计算机病毒成为了一个不可忽视的威胁。为了保护我们的计算机免受病毒的侵害,选择一款优秀的杀毒软件非常重要。本文将带您揭秘世界上最好的杀毒软件,并分析其优势和特点,帮助您...2025-11-04小米冰箱的优点和特点(了解小米冰箱的功能和性能,为您的生活带来便利与舒适)
摘要:小米作为一家知名科技公司,不仅在智能手机领域有着突出的表现,还逐渐涉足家电领域。小米冰箱作为小米家电系列中的一员,拥有许多令人惊艳的特点和功能。本文将详细介绍小米冰箱的优点和特点,...2025-11-04- 摘要:随着中国电影产业的蓬勃发展,儒意影业作为一家秉承儒家文化理念的制片公司,备受瞩目。本文将探讨儒意影业的发展历程,分析其成功之处以及未来的潜力。1.独特的文化定位:坚持以儒家...2025-11-04
 - 摘要:在信息时代的今天,通信技术已成为人类社会联系和信息传递的基石。然而,传统的通信方式逐渐显现出瓶颈,无法满足日益增长的数据传输需求和多样化的通信需求。人们迫切需要一种能够超越传统通讯...2025-11-04
 解决电脑开CF弹窗删除错误的有效方法(快速清除电脑中的CF弹窗错误,提升游戏体验)
摘要:在玩CF游戏时,电脑经常出现弹窗删除错误,这不仅影响游戏体验,还可能引起电脑运行速度变慢甚至系统崩溃。解决电脑开CF弹窗删除错误成为了许多游戏玩家关注的焦点。本文将介绍一些有效的方...2025-11-04- 摘要:聚创伟夜作为一项创新科技活动,吸引了全球众多科技爱好者和创业者的关注。本文将介绍聚创伟夜的背景和目标,并深入探讨其对未来科技发展的意义。标题与1.科技创新的嘉年华——聚...2025-11-04
 

最新评论