Rsdoctor 提供了 Bundle Size
模块,该模块主要用于分析 Webpack 或 Rspack 构建产物的信息,包括当前编译产物的资源大小、重复包、模块引用关系等:
Bundle Analysis
)模块:分析构建产物资源(Assets)以及所包含的 Modules 的大小和代码信息。在该模块中,可以查看 Assets 中 Module 打包后的实际代码大小,以及模块的原始代码或打包后的代码段以及模块引用关系。点击导航栏 「Bundle Size」-> 「Bundle Size」选项,即可查看 Bundle 分析报告。请注意,要展示此页面,需要开启构建产物分析能力 features。
Assets
:资源是对图像、字体、媒体和其他文件类型的统称,是最终存在于输出文件夹内的文件,同时,每个 Chunk 都有对应的 Assets 资源。Module
:一个或多个 Module 组合成了 Chunk。有关 Module 类型的详细信息,请参阅 Rspack Modules 和 Webpack Modules。Bundle Size
:资源产物的最终打包大小,这是构建器处理后的最终大小。Module Bundled Source & Size
:Module Parsed Source 是指 Module 在打包产物中的最终代码片段,Module Parsed Size 是指 Module 在打包产物中的最终代码片段的大小。Package Count
:第三方包的数量。Initial Chunk
: initial(初始化) 是入口起点的主 Chunk,该 chunk 包含入口起点指定的所有模块及其依赖项,与「按需加载」的 Chunk 资源不同。
Duplicate Packages
: 打包到项目中的重复的第三方包。不包括未打包进产物的第三方包,请参阅重复第三方包。Concatenated Module
: 串联模块是将多个模块在打包时提升或串联到一个闭包中。在过去,Webpack 在打包时会将每个模块都打包到单独的闭包中,这种封装函数会导致 JavaScript 在浏览器中执行时较慢。可以通过打开 optimization.concatenateModules
参数来进行优化。产物概览显示了 Total Files
等文件数目和大小信息。点击卡片图表可以展开资源详情,如下图所示:
更多信息,请参阅重复第三方包
如果项目基于 Rspack 且版本低于 0.5.1,无法查看代码信息。
Bundle Analysis 模块用于分析构建产物资源(Assets)以及所包含的 Modules 的大小和代码信息。示例图如下:
顶部工具栏从左到右依次是:搜索 Assets
工具、筛选 Assets
大小工具、筛选 Module
大小工具。
Assets
的关键词,可以搜索对应的 Assets
。Size
的 Assets
资源。Size
的 Module
资源。Assets 标签如左图所示,从左到右依次代表:资源体积、Initial Chunk 和 代码查看。
Modules 标签如右图所示,从左到右依次代表:
concatenated
的模块是串联模块,对此值有一定影响,请参阅下方的 concatenated module
解释。Modules
;Module
内。这种子模块无法继续拆解打包后的代码,因此无法得知具体的 Bundled Size
,只能得知整个串联模块的大小,该大小标注在主模块尾部。Module
之间的依赖关系分析页面。Source
(源码)、Transformed
(编译后代码)和 Bundled
(打包后代码)。点击 「Bundle Size」 页面的 「Bundle Analyzer Graph」 按钮,可以查看经典的瓦片图。
开启 BannerPlugin 分析时,请勿在生产版本中使用 Rsdoctor。
由于 Rspack 和 Webpack 都支持 BannerPlugin,BannerPlugin 是可在生成的 chunk 顶部或尾部添加一段指定的内容的内置插件。 添加的代码段将会影响到对 Bundle 的解析能力。
Rsdoctor 兼容了对 BannerPlugin 这种添加代码的逻辑,但因为 Rsdoctor 需要添加标记代码,所以没有默认开启,以下两种情况会开启 Rsdoctor BannerPlugin 能力:
项目在 rspack.config.j|ts
或 webpack.config.j|ts
中使用了 BannerPlugin;
通过 Rsdoctor options 配置 supports.banner 来开启:
drop_console
将会影响 Rsdoctor 对 BannerPlugin 的分析,所以可以在 RSDOCTOR = true
时,关闭 drop_console
。