React
在这篇文档中,你可以了解到如何基于 Rsbuild 来构建一个 React 应用。
创建 React 项目
你可以使用 create-rsbuild
来创建一个 Rsbuild + React 的项目,调用以下命令:
npm create rsbuild@latest
然后在 Select framework
时选择 React
即可。
在已有项目中使用 React
为了能够编译 React,你需要注册 Rsbuild 的 React 插件,插件会自动添加 React 构建所需的配置。
例如,在 rsbuild.config.ts
中注册:
rsbuild.config.ts
import { defineConfig } from '@rsbuild/core';
import { pluginReact } from '@rsbuild/plugin-react';
export default defineConfig({
plugins: [pluginReact()],
});
TIP
对于使用 Create React App 的项目,可以参考 CRA 迁移指南。
使用 SVGR
Rsbuild 支持调用 SVGR,将 SVG 图片转换为一个 React 组件使用。
如果你需要使用 SVGR,需要注册 Rsbuild 的 SVGR 插件。
React Fast Refresh
Rsbuild 使用 React 官方的 Fast Refresh 能力来进行组件热更新。
注意 React Refresh 要求组件按照规范的方式编写,否则热更新可能无效,你可以使用 eslint-plugin-react-refresh 进行校验。
比如,如果 React 组件的热更新无法生效,或者是热更新后 React 组件的 state 丢失,这通常是因为你的 React 组件使用了匿名函数。在 React Fast Refresh 的官方实践中,要求组件不能为匿名函数,否则热更新后无法保留 React 组件的 state。
以下是一些错误用法的例子:
// 错误写法 1
export default function () {
return <div>Hello World</div>;
}
// 错误写法 2
export default () => <div>Hello World</div>;
正确用法是给每个组件函数声明一个名称:
// 正确写法 1
export default function MyComponent() {
return <div>Hello World</div>;
}
// 正确写法 2
const MyComponent = () => <div>Hello World</div>;
export default MyComponent;
React Compiler
React Compiler 是 React 19 引入的一个实验性编译器,它可以自动优化你的 React 代码。
在开始使用 React Compiler 之前,建议阅读 React Compiler 文档,以了解 React Compiler 的功能、当前状态和使用方法。
如何使用
在 Rsbuild 中使用 React Compiler 的步骤如下:
- 升级
react
和 react-dom
版本到 19。如果你暂时无法升级,可以在 React 17 或 18 项目中安装 react-compiler-runtime,以允许编译后的代码在 19 之前的版本上运行。
- 目前 React Compiler 仅提供了 Babel 插件,你需要安装 @rsbuild/plugin-babel 和 babel-plugin-react-compiler。
- 在你的 Rsbuild 配置文件中注册 Babel 插件:
rsbuild.config.ts
import { defineConfig } from '@rsbuild/core';
import { pluginBabel } from '@rsbuild/plugin-babel';
import { pluginReact } from '@rsbuild/plugin-react';
export default defineConfig({
plugins: [
pluginReact(),
pluginBabel({
include: /\.(?:jsx|tsx)$/,
babelLoaderOptions(opts) {
opts.plugins?.unshift('babel-plugin-react-compiler');
},
}),
],
});
你也可以参考 示例项目。
配置
通过以下方式来传入 React Compiler 的配置:
rsbuild.config.ts
import { defineConfig } from '@rsbuild/core';
import { pluginBabel } from '@rsbuild/plugin-babel';
import { pluginReact } from '@rsbuild/plugin-react';
const ReactCompilerConfig = {
/* ... */
};
export default defineConfig({
plugins: [
pluginReact(),
pluginBabel({
include: /\.(?:jsx|tsx)$/,
babelLoaderOptions(opts) {
opts.plugins?.unshift([
'babel-plugin-react-compiler',
ReactCompilerConfig,
]);
},
}),
],
});
对于 React 17 和 18 的项目,除了安装 react-compiler-runtime,还需要指定 target
:
rsbuild.config.ts
const ReactCompilerConfig = {
target: '18', // '17' | '18' | '19'
};
Router
TanStack Router
TanStack Router 是一个类型安全的 React 路由,内置数据获取、缓存和一流的 search-param API。
TanStack Router 提供了 @tanstack/router-plugin
来与 Rsbuild 集成,该插件支持基于文件的路由,详见:
CSS-in-JS
使用 styled-components
Rsbuild 支持编译 styled-components,优化调试体验,并对 styled-components 添加服务器端渲染支持。
如果你需要使用 styled-components, 我们推荐使用 @rsbuild/plugin-styled-components。
你可以参考这个示例:styled-components。
使用 Emotion
Rsbuild 支持编译 Emotion,你可以添加以下配置来使用:
rsbuild.config.ts
import { defineConfig } from '@rsbuild/core';
import { pluginReact } from '@rsbuild/plugin-react';
export default defineConfig({
plugins: [
pluginReact({
swcReactOptions: {
importSource: '@emotion/react',
},
}),
],
tools: {
swc: {
jsc: {
experimental: {
plugins: [['@swc/plugin-emotion', {}]],
},
},
},
},
});
你可以参考这个示例:emotion。
使用 styled-jsx
你可以通过 @swc/plugin-styled-jsx 来使用 styled-jsx:
rsbuild.config.ts
import { defineConfig } from '@rsbuild/core';
import { pluginReact } from '@rsbuild/plugin-react';
export default defineConfig({
plugins: [pluginReact()],
tools: {
swc: {
jsc: {
experimental: {
plugins: [['@swc/plugin-styled-jsx', {}]],
},
},
},
},
});
请注意,你需要选择和当前 @swc/core
版本匹配的 SWC 插件,才能使 SWC 正常执行,详见 tools.swc。
你可以参考这个示例:styled-jsx。
Rsbuild 支持使用 @vanilla-extract/webpack-plugin 插件,你可以添加以下配置来使用 vanilla-extract:
rsbuild.config.ts
import { defineConfig } from '@rsbuild/core';
import { pluginReact } from '@rsbuild/plugin-react';
import { VanillaExtractPlugin } from '@vanilla-extract/webpack-plugin';
export default defineConfig({
plugins: [
pluginReact({
reactRefreshOptions: {
exclude: [/\.css\.ts$/],
},
}),
],
tools: {
rspack: {
plugins: [new VanillaExtractPlugin()],
},
},
});
你可以参考这个示例:vanilla-extract。
使用 StyleX
你可以通过 unplugin-stylex 来使用 StyleX:
rsbuild.config.ts
import { defineConfig } from '@rsbuild/core';
import { pluginReact } from '@rsbuild/plugin-react';
import stylexPlugin from 'unplugin-stylex/rspack';
export default defineConfig({
plugins: [pluginReact()],
tools: {
rspack: {
plugins: [stylexPlugin()],
},
},
});
你可以参考这个示例:stylex。