React SSR的探索学习

2022-08-11 19:38:58 浏览数 (1)

找了很多开源的react SSR 项目 都不算稳定,

最重选择了:react-koa2-ssr

项目搭建成功之后 配置了一下路由发现报错:

BorwserRouter out must have a Dom

大概意思就是说 我们用的BorwserRouter需要外面加一个标签dom

解决方案:

src/index.js

代码语言:javascript复制
import React from "react";
import ReactDOM from "react-dom";
import { BrowserRouter } from "react-router-dom";
import "./index.css";
import App from "./App.jsx";
import * as serviceWorker from "./serviceWorker";

ReactDOM.hydrate(
  <BrowserRouter>
    <App />
  </BrowserRouter>,
  document.getElementById("root")
);

serviceWorker.unregister();

server/app.js

代码语言:javascript复制
import { StaticRouter} from "react-router-dom";
     ctx.response.body = shtml.replace(
        "{{root}}",
        renderToString(
          <StaticRouter>
            <App />
          </StaticRouter>
        )
      );

完事就可以了

配置的参考文档:

https://zhuanlan.zhihu.com/p/52693113

(参考其中的相关配置 ,但用的是https://github.com/Bill-Pang/react-koa2-ssr)

0 人点赞