本节内容派生于以下链接指向的内容 ,并遵守 CC BY 4.0 许可证的规定。
以下内容如果没有特殊声明,可以认为都是基于原内容的修改和删减后的结果。
优化:该选项用于自定义优化配置。你可以通过 optimization 来自定义优化配置。默认情况下,Rspack 会根据 mode 来选择合适的优化配置。
boolean
true
如果一个 Chunk 的模块都已经被包含在其所有的父 Chunk 中,那么这个模块就可以被移除。
在上面的例子中,b.js
都已经被包含在 EntryChunk
和 EntryChunk2
,所以 b.js
可以从 ChunkFoo
中移除。
production
模式下开启这个优化。'named' | 'deterministic'
选项 | 描述 |
---|---|
named |
使用有意义、方便调试的内容当作模块 id。此选项会在开发环境下默认开启。 |
deterministic |
使用对模块标识符哈希后的数字当作模块 id,有益于长期缓存。此选项会在生产环境下默认开启。 |
'named' | 'deterministic'
选项 | 描述 |
---|---|
'named' |
使用有意义、方便调试的内容当作 Chunk id。此选项会在开发环境下默认开启。 |
'deterministic' |
简短的数字 id,在多次编译的场景下,会尽量保持其稳定性。适合长期缓存。此选项会在生产环境下默认开启。 |
boolean
true
是否合并重复 Chunk,设置成 false
会关掉合并重复 Chunk 行为。
当前该优化可能会对性能有很大的影响。optimization.splitChunks
,而且将 optimization.splitChunks.chunks
设置为了 'all',就可以关掉 optimization.mergeDuplicateChunks
。
如果你正遇到性能问题,并且你在使用
boolean
true
, development 模式 为false
是否对产物进行压缩。
Array<Plugin>
[]
自定义压缩器。当使用自定义压缩器时,内置压缩器将会被禁用。
boolean
true
移除打包过程中产生的空 Chunk。
告诉 Rspack 识别 package.json 中的 sideEffects
标志或者 module.rules
(模块配置中的规则),当模块导出都未被使用且模块本身没有副作用时跳过模块及其子树。
optimization.sideEffects
依赖于 builtins.treeShaking
的启用。这种配置项开启后有额外的构建时间开销,但移除模块对性能有积极影响,因为这意味着更少的代码生成。这种优化的效果取决于你的代码库。
如果你只想使用通过(package.json
和 module.rule.sideEffects
)配置的 sideEffects
,而不想分析代码:
optimization.sideEffects
为 true
时,Rspack 会在一个模块中所有的语句(statement)都没有副作用时标记该模块为无副作用。
在产物处理完成后,添加额外的哈希计算步骤根据产物的文件内容计算该产物的哈希。该功能在生产环境下会默认开启。
如果将 realContentHash 设置为 false,则使用编译流程中的内部数据计算哈希,在某些情况下,即使产物内容完全一致也可能导致哈希变化。
false | object
Rspack 支持通过 optimization.splitChunks
配置项来对 Chunk 进行拆分。
该优化选项默认情况下是开启的,你可以将其设为 false
来关闭它。
点击 SplitChunksPlugin 查看可用配置项
boolean | 'global'
true
, development mode isfalse
告诉 rspack 对每个模块确定使用的导出。这取决于 optimization.providedExports
。
optimization.usedExports
收集的信息被其他优化或代码生成使用,即不会为未使用的导出生成导出信息,当所有用法兼容时,导出名称会被缩短为单个字符标识符。压缩器中的死代码消除将受益于此,并且可以删除未使用的导出。
如果需要在运行时取消使用的导出分析:
boolean
true
, development mode isfalse
optimization.innerGraph
告诉 rspack 是否进行未使用导出的内部图分析。
boolean
true
告诉 rspack 弄清楚模块提供哪些导出,以为 export * from ....
生成更有效的代码。默认情况下,optimization.providedExports
已启用。
boolean | 'deterministic' | 'size'
deterministic
, development mode isfalse
optimization.mangleExports
允许控制导出名称的混淆。
支持以下选项:
option | description |
---|---|
'named' | 使用有意义且易于调试的内容作为标识符。在开发模式下,默认启用此选项。 |
| 'deterministic' | 使用哈希模块标识符作为标识符,以便从长期缓存中受益。在生产模式下,默认启用此选项。| | true |与 'deterministic' 相同。 |
| false |保留原始名称。适用于可读性和调试。 |