Rsbuild optimizes build performance by default, but as the project becomes larger, you may encounter some build performance problems.
This document provides some optional speed-up methods, developers can choose some of them to improve the build performance.
Performing a performance analysis can help you identify performance bottlenecks in your project, allowing for targeted optimization.
Please refer to the Performance Building Analysis section for more information.
The following are some general optimization methods, which can speed up the development build and production build.
Optimizing the number of modules referenced by the application can reduce the bundle size and improve build performance. Please read the Bundle Size Optimization section to learn some optimization methods.
When using Tailwind CSS, if the content
field in tailwind.config.js
is not correctly configured, this can lead to poor build performance and HMR performance.
Please refer to Tailwind CSS - Optimize Build Performance for more details.
The following are methods for improving performance in development mode.
Enabling lazy compilation can significantly reduce the number of modules compiled at dev startup and improve startup time.
Please refer to dev.lazyCompilation for more information.
In order to provide a good debugging experience, Rsbuild uses the cheap-module-source-map
format source map by default in development mode, which is a high-quality source map format and will bring certain performance overhead.
You can improve build speed by adjusting the source map format in development mode through output.sourceMap.
For example to disable source map:
Or set the source map format of the development mode to the cheapest eval
format:
For detailed differences between different source map formats, see Rspack - devtool.
This strategy is similar to "Adjust Browserslist", the difference is that we can set different browserslist for development and production mode, thereby reducing the compilation overhead in development mode.
For example, you can add the following config to .browserslistrc
, which means that only the latest browsers are compatible in development mode, and the actual browsers are compatible in the production mode:
Note that this can lead to some differences in the build result between development and production modes.