renderToStaticMarkup
会将非交互的 React 组件树渲染成 HTML 字符串。
const html = renderToStaticMarkup(reactNode)
参考
renderToStaticMarkup(reactNode)
在服务器上,调用 renderToStaticMarkup
将你的应用程序渲染成 HTML。
import { renderToStaticMarkup } from 'react-dom/server';
const html = renderToStaticMarkup(<Page />);
它将会生成 React 组件的非交互式 HTML 输出。
参数
reactNode
:你想渲染成 HTML 的 React 节点。例如,像<Page />
这样的 JSX 节点。
返回值
一个 HTML 字符串。
注意事项
-
renderToStaticMarkup
的输出无法进行二次渲染。 -
renderToStaticMarkup
对 Suspense 的支持有限。如果一个组件触发了 Suspense,renderToStaticMarkup
立即将它的 fallback 作为 HTML 输出。 -
renderToStaticMarkup
在浏览器中可以使用,但不建议在客户端代码中使用它。如果你需要在浏览器中将组件渲染成 HTML,请把它渲染到 DOM 节点中以获取 HTML。
用法
将一个非交互式的 React 树作为 HTML 渲染成一个字符串
调用 renderToStaticMarkup
将你的应用程序渲染为 HTML 字符串,然后将其与服务器响应一起发送:
import { renderToStaticMarkup } from 'react-dom/server';
// 路由处理程序语法取决于你的后端框架
app.use('/', (request, response) => {
const html = renderToStaticMarkup(<Page />);
response.send(html);
});
这将生成 React 组件的非交互式 HTML 输出。