CSS-in-JS
警告:目前服务端组件不支持需要运行时 JavaScript 的 CSS-in-JS 库。要在服务端组件和流式传输等新 React 功能中使用 CSS-in-JS,需要库作者支持最新版本的 React,包括并发渲染。
我们正与 React 团队合作开发上游 API,以处理支持 React 服务端组件和流式架构的 CSS 和 JavaScript 资源。
以下库在 app
目录的客户端组件中受支持(按字母顺序排列):
kuma-ui
@mui/material
pandacss
styled-jsx
styled-components
style9
tamagui
tss-react
vanilla-extract
以下库正在开发支持中:
须知:我们正在测试不同的 CSS-in-JS 库,并将为支持 React 18 功能和/或
app
目录的库添加更多示例。
如果要为服务端组件添加样式,建议使用 CSS 模块或其他输出 CSS 文件的解决方案,如 PostCSS 或 Tailwind CSS。
在 app
中配置 CSS-in-JS
配置 CSS-in-JS 是一个三步选择加入过程,包括:
- 一个样式注册表,用于收集渲染中的所有 CSS 规则。
- 新的
useServerInsertedHTML
钩子,用于在使用这些规则的任何内容之前注入规则。 - 一个客户端组件,在初始服务端渲染期间用样式注册表包裹您的应用。
styled-jsx
在客户端组件中使用 styled-jsx
需要 v5.1.0
版本。首先,创建一个新的注册表:
然后,用注册表包裹您的根布局:
查看示例。
Styled Components
以下是如何配置 styled-components@6
或更新版本的示例:
首先,使用 styled-components
API 创建一个全局注册表组件,用于收集渲染期间生成的所有 CSS 样式规则,以及一个返回这些规则的函数。然后使用 useServerInsertedHTML
钩子将注册表中收集的样式注入到根布局的 <head>
HTML 标签中。
用样式注册表组件包裹根布局的 children
:
查看示例。
须知:
- 在服务端渲染期间,样式将被提取到全局注册表并刷新到 HTML 的
<head>
中。这确保样式规则在使用它们的任何内容之前放置。未来,我们可能会使用即将推出的 React 功能来确定注入样式的位置。- 在流式传输期间,每个块的样式将被收集并附加到现有样式中。客户端水合完成后,
styled-components
将像往常一样接管并注入任何进一步的动态样式。- 我们特意在树的顶层使用客户端组件作为样式注册表,因为这种方式提取 CSS 规则更高效。它避免了在后续服务端渲染时重新生成样式,并防止它们被发送到服务端组件负载中。