本节内容派生于以下链接指向的内容 ,并遵守 CC BY 4.0 许可证的规定。
以下内容如果没有特殊声明,可以认为都是基于原内容的修改和删减后的结果。
优化:该选项用于自定义优化配置。你可以通过 optimization 来自定义优化配置。默认情况下,Rspack 会根据 mode 来选择合适的优化配置。
'natural' | 'named' | 'deterministic'| 选项 | 描述 |
|---|---|
natural |
根据模块加载的顺序使用自增数字作为模块 id。 |
named |
使用有意义、方便调试的内容当作模块 id。此选项会在开发环境下默认开启。 |
deterministic |
使用对模块标识符哈希后的数字当作模块 id,有益于长期缓存。此选项会在生产环境下默认开启。 |
'named' | 'deterministic'| 选项 | 描述 |
|---|---|
'named' |
使用有意义、方便调试的内容当作 Chunk id。此选项会在开发环境下默认开启。 |
'deterministic' |
简短的数字 id,在多次编译的场景下,会尽量保持其稳定性。适合长期缓存。此选项会在生产环境下默认开启。 |
booleantrue是否合并重复 Chunk,设置成 false 会关掉合并重复 Chunk 行为。
booleantrue, development 模式 为false是否对产物进行压缩。
Array<Plugin>[new SwcJsMinimizerRspackPlugin(), new LightningCssMinimizerRspackPlugin()]自定义压缩器。默认使用 rspack.SwcJsMinimizerRspackPlugin
和 rspack.LightningCssMinimizerRspackPlugin。当声明了 optimization.minimizer,默认压缩器会被禁用。
使用内置压缩器和自定义选项:
booleantrue移除打包过程中产生的空 Chunk。
boolean | string | ((entrypoint: { name: string }) => string)false用来控制 runtime chunk 如何生成。
设置为 true 或 'multiple' 会为每个入口点添加一个仅包含运行时的额外 chunk。
设置为 'single' 会将所有入口点的运行时代码抽离到一个单独的 chunk。
boolean | 'flag'true, development 模式 为false在产物处理完成后,添加额外的哈希计算步骤根据产物的文件内容计算该产物的哈希。该功能在生产环境下会默认开启。
如果将 realContentHash 设置为 false,则使用编译流程中的内部数据计算哈希,在某些情况下,即使产物内容完全一致也可能导致哈希变化。
false | objectRspack 支持通过 optimization.splitChunks 配置项来对 Chunk 进行拆分。
该优化选项默认情况下是开启的,你可以将其设为 false 来关闭它。
有关配置此行为的可用选项,请参见 SplitChunksPlugin 页面。
booleantrue开启后 Rspack 将会分析模块提供哪些导出,包括重导出模块,引用模块不存在的导出时会发出提示。默认情况下,optimization.providedExports 已启用,该分析会增加构建时间,你可以考虑在 development 模式中关闭该配置,关闭后有可能会遇到SideEffects 章节运行时循环依赖的错误。
boolean | 'flag'true, development 模式 为'flag'告诉 Rspack 识别 package.json 中的 sideEffects 标志或者 module.rules(模块配置中的规则),以跳过那些被标记为没有副作用但未被使用的模块。
请注意,如果你的项目需要使用 npm 模块的话,sideEffects 应该在 npm 模块的 package.json 文件中,并需要在你自己的项目的 package.json 中将 sideEffects 设置为 false。
optimization.sideEffects 依赖于启用 optimization.providedExports。这在构建时会有一定的成本,但消除模块对性能有积极的影响,因为生成的代码更少。这个优化的效果取决于你的代码库,尝试使用它来获得可能的性能提升。
如果你只希望 Rspack 使用手动指定的 sideEffects 标志(通过 package.json 和 module.rule.sideEffects),而不分析源代码,可以这样配置:
默认情况下,'flag' 值在非生产环境构建中使用。
当 optimization.sideEffects 为 true 时,如果模块中只包含无副作用的语句,Rspack 也会将它们标记为无副作用。
boolean | 'global'true, development 模式 为false告诉 Rspack 对每个模块确定使用的导出。这取决于 optimization.providedExports。
optimization.usedExports 收集的信息被其他优化或代码生成使用,即不会为未使用的导出生成导出信息,当所有用法兼容时,导出名称会被缩短为单个字符标识符。压缩器中的死代码消除将受益于此,并且可以删除未使用的导出。
如果需要在运行时取消使用的导出分析:
boolean | 'deterministic' | 'size' deterministic, development 模式 为falseoptimization.mangleExports 允许控制导出名称的混淆。
支持以下选项:
| option | description |
|---|---|
| 'named' | 使用有意义且易于调试的内容作为标识符。在开发模式下,默认启用此选项。 |
| 'deterministic' | 使用哈希模块标识符作为标识符,以便从长期缓存中受益。在生产模式下,默认启用此选项。 |
| true | 与 'deterministic' 相同。 |
| false | 保留原始名称。适用于可读性和调试。 |
booleantrue, development 模式 为falseoptimization.innerGraph 告诉 Rspack 是否对变量传递进行更详细的分析,这有助于 Rspack 识别未使用的模块导出,从而减少打包产物的体积。
例如:
这里我们将 value 赋值给了 value2,value2 和 value 也分别在函数 f2 和 f1 中被访问,但函数没有被调用,因此没有使用到 value2 和 value,因此 value 的导入是可以被删除的。
booleantrue, development 模式 为false开启模块拼接优化,允许将多个模块拼接成单个模块以降低产物体积,提升压缩效率。此优化需要开启 optimization.providedExports 和 optimization.usedExports。默认情况下,optimization.concatenateModules 在 production 模式下启用,其它模式则禁用。
boolean | stringfalseRspack 将 process.env.NODE_ENV 设置为给定的字符串。除非该值被明确设置为 false,否则 optimization.nodeEnv 将使用 DefinePlugin。
optimization.nodeEnv 的默认值为 mode,否则将设置为 'production'。
可能的值:
process.env.NODE_ENV 的值。process.env.NODE_ENV 的值。当 mode 被设置为 'none' 时,optimization.nodeEnv 默认为 false。
booleanfalse, development 模式 为true开启 optimization.emitOnErrors 时,即使编译过程中发生错误也会生成产物。关键错误会被注入到产物代码中,运行它们时会抛出错误。