
正在开发个 React 应用,有 5 个页面,每个页面的某些区域只有登录之后才能使用,我又想让搜索引擎能抓到这 5 个页面。
为啥不能用 Next.js 的原因是:
Next 的 Router 太封闭了。我这应用用不了,我魔改了一下 React Router 的 Outlet 搞了一个 Tab 页功能,自己控制页面渲染。
求助!
1 horizon 2024 年 9 月 5 日 vite ssr |
2 skallz 2024 年 9 月 5 日 如果只是针对搜索引擎的话,使用 prerender 预渲染相关的库,网上一搜一大把,然后针对搜索引擎的请求返回组装好的页面,普通用户还是浏览 spa 页面,对项目无侵入性 |
3 xu33 2024 年 9 月 5 日 ssg |
4 dumbass 2024 年 9 月 5 日 |
5 importmeta OP @horizon 暂时切不了 Vue... |
6 importmeta OP @skallz 感觉这个好,判断爬虫就给预渲染完成的 |
7 importmeta OP @xu33 SSG 生成的是静态的 html 吧,这里面能写交互吗? |
8 horizon 2024 年 9 月 5 日 @importmeta #5 react 也支持 |
9 xu33 2024 年 9 月 5 日 @importmeta 跟交互没关系吧,不管 ssr ,ssg 还是 csr ,交互都在 js 里 |
10 importmeta OP |
11 dudubaba 2024 年 9 月 5 日 打包的时候用生成 html 不就行了,其实就是 ssr 的原理。但是你这不需要那么复杂,只要能抓取就行,本地 mock 一份登录后才能获取的静态 josn 数据,然后 react 的 rendertostring 生成字符串再用 fs 写入文件。 |
12 flmn 2024 年 9 月 5 日 Astro 了解一下,island |
13 seeu2ex 2024 年 9 月 6 日 via iPhone React 的 server component 可以,你可以看看 |