产物分析
如果想要分析某个 Module 的引用链路,可以查看 👉🏻Module 引用链分析。
⭐️ 功能概览
Rsdoctor 提供了 Bundle Size 模块,该模块主要用于分析 Webpack 或 Rspack 构建产物的信息,包括当前编译产物的资源大小、重复包、模块引用关系等:
- 产物概览:展示产物总数、各类型文件数目、大小以及占比,以及重复包和重复包的引用链,👉🏻 产物概览
- 产物分析(
Bundle Analysis)模块:分析构建产物资源(Assets)以及所包含的 Modules 的大小和代码信息。在该模块中,可以查看 Assets 中 Module 打包后的实际代码大小、模块的原始代码、打包后的代码段以及模块引用关系。
其中,产物分析展示了两种视图模式,Tree Map 和 Tree Graph:
- 👉🏻 Tree Map
Tree Map 是一种经典的构建产物分析视图,能帮助开发者更直观地可视化并分析 bundle 的构成,以及资源(Assets)和模块(Modules)的占比。同时支持搜索模块资源,点击模块资源可以放大到该模块区域。
- 👉🏻 Tree Graph
Tree Graph 是一种基于文件树形式的构建产物分析视图,能帮助开发者更直观地可视化并分析产物的构成,以及产物(Assets)和模块(Modules)的占比。同时支持搜索模块资源,点击模块还可以查看模块详情和代码。
🪐 名词解释
Assets:资源是最终存在于输出文件夹内的文件,包括 JavaScript、CSS、图像、字体、媒体等文件类型。每个 Chunk 都有对应的 Assets 资源。Module:多个 Module 组合成了 Chunk。有关 Module 类型的详细信息,请参阅 Rspack Modules 和 Webpack Modules。Source Size:文件的原始大小,未经过任何转换和压缩。Bundle Size:文件最终输出的大小。如果开启了压缩,这个值代表压缩后的大小。Gzip Size:文件经过 gzip 压缩后的大小。Package Count:第三方包的数量。Initial Chunk: initial(初始化) 是入口起点的主 Chunk,该 Chunk 包含入口起点指定的所有模块及其依赖项,与「按需加载」的 Chunk 资源不同。- 有关 Initial Chunk 的详细信息,请参阅 Initial Chunk 介绍。
Duplicate Packages: 打包到项目中的重复的第三方包。不包括未打包进产物的第三方包,请参阅重复第三方包。Concatenated Module: 串联模块是将多个模块在打包时提升或串联到一个闭包中。在过去,Webpack 在打包时会将每个模块都打包到单独的闭包中,这种封装函数会导致 JavaScript 在浏览器中执行时较慢。可以通过开启optimization.concatenateModules参数来进行优化。
🪐 产物概览
产物信息卡
产物概览显示了 Total Files 等文件数目和大小信息。点击卡片可以展开资源详情,如下图所示:
- 点击详情图标,右侧会展示对应的资源树,并标明资源大小:
- 点击标签切换资源信息查看,例如:「Total JS | Initial JS」。同时,卡片上展示了资源的体积占比、体积大小以及资源数目。同样,点击右下图标可以展开资源列表。
重复第三方包
- Duplicate Packages 卡片上展示了项目中重复的第三方包数量。点击图片可以查看重复第三方包的具体详情。请注意,这里的第三方包是被打包的第三方包。
更多信息,请参阅重复第三方包
🪐 Tree map
如果一个 Asset 区块中没有 Module 分块,则需要手动开启 SourceMap。注意只在 Rsdoctor 开启时打开 SourceMap,不要影响线上产物。FAQ
Tree Map 视图可以直观展示各个模块之间的占比和关系,如下图所示。点击模块资源可以放大到该模块区域。
- Tree Map 视图也支持搜索模块资源,左侧的侧边栏可以过滤资源(Assets)和搜索模块(Modules)。点击模块的搜索结果可以放大到该模块区域。
- 双击某个区块可以展示其 Module 详情卡片,如下图所示。更多信息请参阅 Module 详情。
🪐 Tree graph
如果一个 Asset 区块中没有 Module 分块,则需要手动开启 SourceMap。注意只在 Rsdoctor 开启时打开 SourceMap,不要影响线上产物。FAQ
Tree Graph 是一种基于文件树形式的构建产物分析视图,用于分析构建产物资源(Assets)以及所包含的 Modules 的大小和代码信息。在该模块中,可以查看 Assets 中 Module 打包后的实际代码大小、模块的原始代码、打包后的代码段以及模块引用关系。
点击导航栏的「Bundle Size」选项,即可查看 Bundle 分析报告。请注意,要展示此页面,需要开启构建产物分析能力 features。
如果项目基于 Rspack 且版本低于 0.5.1,无法查看代码信息。
资源与模块关系展示
Bundle Analysis 模块用于分析构建产物资源(Assets)以及所包含的 Modules 的大小和代码信息。示例图如下:
- 左侧是 Assets 资源列表,按照资源大小降序排列,可以点击 「expand all」 按钮展开全部节点。
- 右侧是 Assets 对应的 Modules 列表,同样按照打包后模块大小降序排列。
搜索筛选框
顶部工具栏从左到右依次是:搜索 Assets 工具、筛选 Assets 大小工具、筛选 Module 大小工具。
- 搜索 Entry 输入框:在输入框中输入 Entry 的关键词,可以搜索对应的 Entry,只展示该 Entry 下的 Assets 等。
- 搜索 Assets 输入框:在输入框中输入
Assets的关键词,可以搜索对应的Assets。 - Assets Size 筛选工具:填写数字,单位为:KB、MB,可以过滤掉小于所填
Size的Assets资源。 - Module Size 筛选工具:填写数字,单位为:KB、MB,可以过滤掉小于所填
Size的Module资源。
模块搜索功能
支持模块搜索功能,用户可以通过点击「Search Module」按钮,打开模块搜索弹窗。输入模块名称来快速定位和查看模块所在的 Assets,从而更方便地分析模块的引用关系和大小。
如下图,可以看到匹配搜索 Module 关键字的结果:

