Migrate from webpack
Rspack's configuration is designed based on webpack, enabling you to migrate your project from webpack to Rspack with ease.
This document is primarily aimed at projects using webpack 5. Since Rspack's API and configuration align with webpack 5. For projects not using webpack 5, there are other migration guides that can be referenced:
- For projects using webpack v4 or earlier versions, you can refer to webpack - To v5 from v4 to understand the differences.
- For projects using create-react-app or CRACO, you can refer to Migrating Create React App.
- For projects using Vue CLI, you can refer to Rsbuild - Migrating from Vue CLI.
Installing Rspack
Install Rspack in your project directory:
Both @rspack/cli and @rspack/dev-server are optional dependencies:
- If you are not using
webpack-cli, no need to install@rspack/cli. - If you are not using
webpack-dev-server, no need to install@rspack/dev-server.
Now you can remove the webpack-related dependencies from your project:
Updating package.json
Update your build scripts to use Rspack instead of webpack, see CLI for more details.
Updating configuration
Rename the webpack.config.js file to rspack.config.js.
Rspack commands can specify the configuration file with -c or --config, similar to webpack commands.
However, unlike webpack, if a configuration file is not explicitly specified, Rspack defaults to using rspack.config.js.
Rspack supports most webpack configuration options. See Configure Rspack for the complete list of supported options.
Webpack built-in plugins
Rspack has implemented most of webpack's built-in plugins, with the same names and configuration parameters, allowing for easy replacement.
For example, replacing the DefinePlugin:
See Built-in plugins for more information about supported webpack plugins in Rspack.
Community plugins
Rspack supports most of the webpack community plugins and also offers alternative solutions for some currently unsupported plugins.
Check Plugin compat for more information on Rspack's compatibility with popular webpack community plugins.
copy-webpack-plugin
Use rspack.CopyRspackPlugin instead of copy-webpack-plugin:
mini-css-extract-plugin
Use rspack.CssExtractRspackPlugin instead of mini-css-extract-plugin:
tsconfig-paths-webpack-plugin
Use resolve.tsConfig option instead of tsconfig-paths-webpack-plugin:
fork-ts-checker-webpack-plugin
Use ts-checker-rspack-plugin instead of fork-ts-checker-webpack-plugin:
Loaders
Rspack is compatible with most webpack loaders, so existing loaders can typically be reused without changes.
For optimal performance and consistency, we recommend the following migrations where applicable:
babel-loader
Migrate babel-loader to builtin:swc-loader to use Rspack's built-in SWC transform for better performance.
If you need custom transformation logic using Babel plugins, you can retain babel-loader, but it is recommended to limit its use to fewer files to prevent significant performance degradation.
- Replace @babel/preset-typescript with SWC's
syntax: 'typescript'option:
- Replace @babel/preset-react with SWC's
jsc.transform.reactoption:
swc-loader
When migrating external swc-loader to builtin:swc-loader, only the loader name changes to builtin:swc-loader; all the options remain exactly the same as your original swc-loader config.
file-loader
Migrate file-loader to Asset Modules with asset/resource.
url-loader
Migrate url-loader to Asset Modules with asset/inline.
raw-loader
Migrate raw-loader to Asset Modules with asset/source.

