prerender-spa-plugin使用总结

2023-12-30 07:36

本文主要是介绍prerender-spa-plugin使用总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 介绍

prerender-spa-plugin 利用了 Puppeteer 的爬取页面的功能。 Puppeteer 是一个 Chrome官方出品的 headlessChromenode 库。它提供了一系列的 API, 可以在无 UI 的情况下调用 Chrome 的功能, 适用于爬虫、自动化处理等各种场景。它很强大,所以很简单就能将运行时的 HTML 打包到文件中。原理是在 Webpack 构建阶段的最后,在本地启动一个 Puppeteer 的服务,访问配置了预渲染的路由,然后将 Puppeteer 中渲染的页面输出到 HTML 文件中,并建立路由对应的目录

2. Unable to prerender all routes!

  • 1、由于webpack5: mkdirp is no longer expected to be a function on the output file system,如果当前使用的是webpack5版本,需更新插件代码。
  • 2、作者提交的修复版本的分支 https://github.com/jsbugwang/prerender-spa-plugin/tree/webpack5
  • 3、ps:该分支漏了 const fs = require('fs') 的声明,需自行加上
  • 4、ps:可在 perrender-spa-plugin/es6/index.js 中,代码 console.error(msg) 处添加 console.log(err) 输出具体报错原因,以定位问题

3. pyppeteer.errors.TimeoutError: Navigation Timeout Exceeded: 30000 ms.

  • 1、预渲染的路由过多,超过pyppeteer默认的超时时间,减少打包的路由
  • 2、设置 maxConcurrentRoutes: 10

4. 设置publicPath二级目录后,预渲染白屏

  • 1、publicPath: process.env.NODE_ENV === 'production' ? '/vue' : '/'
  • 2、outputDir: path.join(__dirname, 'dist', '/vue')
  • 3、参考链接 https://github.com/chrisvfritz/prerender-spa-plugin/issues/344 #takatama, #cnvoa 的评论
    具体配置如下:
new PrerenderSPAPlugin({indexPath: path.join(__dirname, 'dist/vue/index.html'),// Required - The path to the webpack-outputted app to prerender.staticDir: path.join(__dirname, 'dist'),// Optional - The path your rendered app should be output to.// (Defaults to staticDir.)outputDir: path.join(__dirname, 'dist/vue'),// Required - Routes to render.routes: ['/'],renderer: new Renderer({headless: true, // 是否隐藏无头浏览器(调试时可开启)renderAfterTime: 5000,}),server: {proxy: {'/api': {target: 'http://www.a.c',changOrigin: true,secure: false,},},},
})

5. 预渲染未请求接口数据(一)

  • 1、在配置插件中增加 headless: false ,用以开启无头浏览器进行调试,查看console面板中的错误
  • 2、定位到问题出在发起的接口请求中,打印返回内容为html文本
  • 3、打印查看接口请求地址,为 http://localhost:8080/api/xxx ,原因是代码中接口请求路径为缺省域名的写法,请求时会自动补全当前网页所在的域名
  • 4、更改代码中的请求,补全请求地址,如:http://www.a.c/api/xxx (由于此做法会有跨域问题,并未采用)
  • 5、查看PrerenderSPAPlugin源码发现其使用的服务为express框架,并用到了http-proxy-middleware反向代理,所以只要在插件中增加配置 server 即可解决,具体配置方法与http-proxy-middleware一致

6. 预渲染未请求接口数据(二)

  • 1、在配置插件中增加 headless: false ,用以开启无头浏览器进行调试,查看console面板中的错误
  • 2、接口请求返回500错误,打包界面提示 ERR_TLS_CERT_ALTNAME_INVALID 错误代码
  • 3、定位问题为https证书验证的问题
  • 4、首先确认nginx中的https配置ssl协议是否如下 ssl_protocols: TLSv1 TLSv1.1 TLSv1.2
  • 5、在proxy中增加配置信息 secure: false 以关闭ssl证书验证
    具体配置如下:
new PrerenderSPAPlugin({// Required - The path to the webpack-outputted app to prerender.staticDir: path.join(__dirname, 'dist'),// Optional - The path your rendered app should be output to.// (Defaults to staticDir.)outputDir: path.join(__dirname, 'dist'),// Required - Routes to render.routes: ['/'],renderer: new Renderer({headless: true, // 是否隐藏无头浏览器(调试时可开启)renderAfterTime: 5000,}),server: {proxy: {'/api': {target: 'http://www.a.c',changOrigin: true,secure: false,},},},
})

7. 使用限制

prerender-spa-plugin 仅适用于 history 模式,若为 hash 模式,那么 routes 配置只有根路由可被成功预渲染。

References

[1] https://github.com/chrisvfritz/prerender-spa-plugin

[2] https://github.com/jsbugwang/prerender-spa-plugin/tree/webpack5

这篇关于prerender-spa-plugin使用总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/552138

相关文章

C语言中联合体union的使用

本文编辑整理自: http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=179471 一、前言 “联合体”(union)与“结构体”(struct)有一些相似之处。但两者有本质上的不同。在结构体中,各成员有各自的内存空间, 一个结构变量的总长度是各成员长度之和。而在“联合”中,各成员共享一段内存空间, 一个联合变量

关于C++中的虚拟继承的一些总结(虚拟继承,覆盖,派生,隐藏)

1.为什么要引入虚拟继承 虚拟继承是多重继承中特有的概念。虚拟基类是为解决多重继承而出现的。如:类D继承自类B1、B2,而类B1、B2都继承自类A,因此在类D中两次出现类A中的变量和函数。为了节省内存空间,可以将B1、B2对A的继承定义为虚拟继承,而A就成了虚拟基类。实现的代码如下: class A class B1:public virtual A; class B2:pu

Tolua使用笔记(上)

目录   1.准备工作 2.运行例子 01.HelloWorld:在C#中,创建和销毁Lua虚拟机 和 简单调用。 02.ScriptsFromFile:在C#中,对一个lua文件的执行调用 03.CallLuaFunction:在C#中,对lua函数的操作 04.AccessingLuaVariables:在C#中,对lua变量的操作 05.LuaCoroutine:在Lua中,

Vim使用基础篇

本文内容大部分来自 vimtutor,自带的教程的总结。在终端输入vimtutor 即可进入教程。 先总结一下,然后再分别介绍正常模式,插入模式,和可视模式三种模式下的命令。 目录 看完以后的汇总 1.正常模式(Normal模式) 1.移动光标 2.删除 3.【:】输入符 4.撤销 5.替换 6.重复命令【. ; ,】 7.复制粘贴 8.缩进 2.插入模式 INSERT

Lipowerline5.0 雷达电力应用软件下载使用

1.配网数据处理分析 针对配网线路点云数据,优化了分类算法,支持杆塔、导线、交跨线、建筑物、地面点和其他线路的自动分类;一键生成危险点报告和交跨报告;还能生成点云数据采集航线和自主巡检航线。 获取软件安装包联系邮箱:2895356150@qq.com,资源源于网络,本介绍用于学习使用,如有侵权请您联系删除! 2.新增快速版,简洁易上手 支持快速版和专业版切换使用,快速版界面简洁,保留主

如何免费的去使用connectedpapers?

免费使用connectedpapers 1. 打开谷歌浏览器2. 按住ctrl+shift+N,进入无痕模式3. 不需要登录(也就是访客模式)4. 两次用完,关闭无痕模式(继续重复步骤 2 - 4) 1. 打开谷歌浏览器 2. 按住ctrl+shift+N,进入无痕模式 输入网址:https://www.connectedpapers.com/ 3. 不需要登录(也就是

十五.各设计模式总结与对比

1.各设计模式总结与对比 1.1.课程目标 1、 简要分析GoF 23种设计模式和设计原则,做整体认知。 2、 剖析Spirng的编程思想,启发思维,为之后深入学习Spring做铺垫。 3、 了解各设计模式之间的关联,解决设计模式混淆的问题。 1.2.内容定位 1、 掌握设计模式的"道" ,而不只是"术" 2、 道可道非常道,滴水石穿非一日之功,做好长期修炼的准备。 3、 不要为了

Toolbar+DrawerLayout使用详情结合网络各大神

最近也想搞下toolbar+drawerlayout的使用。结合网络上各大神的杰作,我把大部分的内容效果都完成了遍。现在记录下各个功能效果的实现以及一些细节注意点。 这图弹出两个菜单内容都是仿QQ界面的选项。左边一个是drawerlayout的弹窗。右边是toolbar的popup弹窗。 开始实现步骤详情: 1.创建toolbar布局跟drawerlayout布局 <?xml vers

人工智能机器学习算法总结神经网络算法(前向及反向传播)

1.定义,意义和优缺点 定义: 神经网络算法是一种模仿人类大脑神经元之间连接方式的机器学习算法。通过多层神经元的组合和激活函数的非线性转换,神经网络能够学习数据的特征和模式,实现对复杂数据的建模和预测。(我们可以借助人类的神经元模型来更好的帮助我们理解该算法的本质,不过这里需要说明的是,虽然名字是神经网络,并且结构等等也是借鉴了神经网络,但其原型以及算法本质上还和生物层面的神经网络运行原理存在

Java注解详细总结

什么是注解?         Java注解是代码中的特殊标记,比如@Override、@Test等,作用是:让其他程序根据注解信息决定怎么执行该程序。         注解不光可以用在方法上,还可以用在类上、变量上、构造器上等位置。 自定义注解  现在我们自定义一个MyTest注解 public @interface MyTest{String aaa();boolean bbb()