我是靠谱客的博主 负责棒球,这篇文章主要介绍React app SEO优化之预渲染,现在分享给大家,希望可以做个参考。

阅读本文只需要2分钟

搜索引擎真的需要已经预渲染的应用吗?

谷歌已经明确表示,他们会在抓取你的网站之前运行你的JavaScript代码。准确地说,他们的爬虫(crawler)中运用 Chrome 41浏览器打开网站,和真实用户用浏览器打开一样!但是还有其他搜索引擎和社交媒体网站可能并不会这么做。

我知道人们太关心搜索引擎优化了,总是试图尽可能地提高。很自然的,每个人都想在不运行任何JavaScript的情况下直接显示搜索引擎的内容。这不是一个坏主意,相信很多人都这么尝试过。

*这不仅有利于搜索引擎优化 *,而且还具一些性能优势。浏览器不必等待JS文件加载后才开始渲染,首次有效渲染(First Contentful Paint)的时间会更短。

React App 如何预渲染?

原理其实很简单,在我们使用npm run build构建React App后,我们用真实浏览器渲染build目录(通常是index.html), 然后获取产生的HTML代码保存到一个文件中,只是所有的内部页面都需要重复相同的操作。

感谢react-snap 让这一切变得简单。

  1. dev 依赖中安装  npm i -D react-snap
  2. package.jsonscripts 中添加"postbuild": "react-snap"
  3. 运行npm run build

What it will do is after the normal build, it will run react-snap which will render them in a Puppeteer browser, scrape content and generate new build.

build之后,将运行react-snap,在无头浏览器(Puppeteer browser)中渲染,抓取内容并产生新的build

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
{ "scripts": { "postbuild": "react-snap" }, "reactSnap": { "skipThirdPartyRequests": true }, "devDependencies": { "react-snap": "^1.23.0" } } 复制代码

和原作者一样,我在尝试react-snap的时候,也碰到了一些问题,例如著名的'Protocol error (Runtime.callFunctionOn): Object reference chain is too long' }, 一般在官方问题都能找到相应的解决方案,或者你选择StackOverFlow

所以当我们在使用第三方脚本的时候,应该尽可能对他们多一些了解,比如有哪些限制或者是options, 请参考文档。

原文地址:coffeencoding.com/prerender-r… 感谢作者 Gijo Varghese

最后

以上就是负责棒球最近收集整理的关于React app SEO优化之预渲染的全部内容,更多相关React内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(68)

评论列表共有 0 条评论

立即
投稿
返回
顶部