提升构建性能

Rsbuild 默认对构建性能进行了充分优化,但是随着使用场景变复杂、项目代码量变大,你可能会遇到一些构建性能的问题。

本文档提供了一些可选的提速策略,开发者可以根据实际场景选取其中的部分策略,从而进一步提升构建速度。

TIP

优化产物体积一文中介绍的策略也可以用于提升构建性能,这里不再重复介绍。

性能分析

进行构建性能分析可以帮助你确定项目中的性能瓶颈,从而采取针对性的优化。

请参考 构建性能分析 章节了解更多。

通用优化策略

以下是一些通用的优化策略,对开发环境和生产环境均有提速效果,其中部分策略对包体积也有优化。

启用 Lightning CSS 插件

Lightning CSS 是一个基于 Rust 编写的高性能 CSS 解析、转译和压缩工具。它支持将许多现代的 CSS 特性解析并转化为指定浏览器支持的语法,并提供更好的压缩比例。

Rsbuild 提供了 Lightning CSS 插件,可以使用 lightningcss 替代内置的 postcss-loader 来编译 CSS,解决 PostCSS 和 autoprefixer 性能开销过大的问题。

对于存在大量 CSS 文件的项目,启用 Lightning CSS 插件可以显著提升整体构建性能。

rsbuild.config.ts
import { pluginLightningcss } from '@rsbuild/plugin-lightningcss';

export default {
  plugins: [pluginLightningcss()],
};

开发环境优化策略

以下是针对开发环境进行提速的策略。

调整 Source Map 格式

为了提供良好的调试体验,Rsbuild 在开发环境下默认使用 cheap-module-source-map 格式 Source Map,这是一种高质量的 Source Map 格式,会带来一定的性能开销。

你可以通过调整开发环境的 Source Map 格式来提升构建速度。

比如禁用 Source Map:

export default {
  output: {
    sourceMap: {
      js: false,
    },
  },
};

或是把开发环境的 Source Map 格式设置为开销最小的 eval 格式:

export default {
  output: {
    sourceMap: {
      js: process.env.NODE_ENV === 'development' ? 'eval' : false,
    },
  },
};

关于不同 Source Map 格式之间的详细差异,请查看 Rspack - devtool

调整 Browserslist 范围

这项优化的原理与「提升 Browserslist 范围」类似,区别在于,我们可以为开发环境和生产环境设置不同的 browserslist,从而减少开发环境下的编译开销。

比如,你可以在 .browserslistrc 中添加以下配置,表示在开发环境下只兼容最新的浏览器,在生产环境下兼容实际需要的浏览器:

.browserslistrc
[production]
chrome >= 87
edge >= 88
firefox >= 78
safari >= 14

[development]
last 1 chrome version
last 1 firefox version
last 1 safari version

注意,这项优化策略会导致开发环境与生产环境的构建产物存在一定差异。