Rspack provides two solutions to support React:
Rspack leverages SWC transformer for supporting JSX and TSX.
You can add builtin:swc-loader loader to support .jsx and .tsx files:
Refer to builtin:swc-loader for detailed configurations.
There are currently two ways to enable React Fast Refresh in Rspack:
First you need to install @rspack/plugin-react-refresh to support React Fast Refresh.
Enabling React Fast Refresh functionality primarily involves two aspects: code injection and code transformation.
react-refresh package, as well as some custom runtime code, all of which are integrated in the @rspack/plugin-react-refresh plugin and can be injected through this plugin.Compared to the previous approach, this method decouples the React Fast Refresh code injection logic from the transformation logic. The code injection logic is handled uniformly by the @rspack/plugin-react-refresh plugin, while the code transformation is handled by loaders. This means that this plugin can be used in conjunction with builtin:swc-loader, swc-loader, or babel-loader:
builtin:swc-loader, you can refer to the example at examples/react-refresh, When using with swc-loader, simply replace builtin:swc-loader with swc-loader.babel-loader, you can refer to the example at examples/react-refresh-babel-loaderReact Compiler is an experimental compiler introduced in React 19 that can automatically optimize your React code.
Before you start using React Compiler, it's recommended to read the React Compiler documentation to understand the functionality, current state, and usage of the React Compiler.
At present, React Compiler only supports Babel compilation, which may slow down the build time.
The steps to use React Compiler in Rspack:
react and react-dom to 19. If you are unable to upgrade, you can install the extra react-compiler-runtime package which will allow the compiled code to run on versions prior to 19.babel-loader in your Rspack config file:babel.config.js and configure the plugins:For React 17 and 18 projects, you need to install react-compiler-runtime and specify the target:
You can refer to the following example projects:
SVGR is an universal tool for transforming Scalable Vector Graphics (SVG) files into React components.
The usage of SVGR with Rspack is exactly the same as with Webpack.
For detailed usage of SVGR, please refer to SVGR Documentation - webpack.