vue项目使用prerender-spa-plugin + vue-meta-info seo优化

vue项目使用prerender-spa-plugin + vue-meta-info seo优化

一.安装

prerender-spa-plugin的安装及使用
1.npm install prerender-spa-plugin --save
2.在webpack.prod.config.js 中引入
const PrerenderSPAPlugin = require(‘prerender-spa-plugin’)
const Renderer = PrerenderSPAPlugin.PuppeteerRenderer
在这里插入图片描述
在plugins中加入
new PrerenderSPAPlugin({
// Required - The path to the webpack-outputted app to prerender.
staticDir: path.join(__dirname, ‘…/dist’),
// Required - Routes to render.
routes: [ ‘/’, ‘/InformationCentreListF’,’/InformationCentreListB’, ‘/InformationDetails’], //这里填写你需要预加载的页面
renderer: new Renderer({
inject: {
foo: ‘bar’
},
headless: false,
// 在 main.js 中 document.dispatchEvent(new Event(‘render-event’)),两者的事件名称要对应上。
renderAfterDocumentEvent: ‘render-event’
})
})
在这里插入图片描述
3.在main.js 中加入 mounted () {
document.dispatchEvent(new Event(‘render-event’))
}
在这里插入图片描述
vue-meta-info安装及使用
1.npm install vue-meta-info --save
2.在main.js中加入
import MetaInfo from ‘vue-meta-info’
Vue.use(MetaInfo)
3.在需要配置的页面加入
metaInfo: {
title: ‘标题’, // set a title
meta: [{ // set meta
name: ‘name’,
content: ‘内容’
}],
link: [{ // set link
rel: ‘assets’,
href: ‘https://assets-cdn.github.com/
}]
},
在这里插入图片描述

排坑

**首先路由模式必须是 history 模式;
1.在安装完成之后npm run build,可能会出现报错提示puppeteer unable …的错误,因为prerender-spa-plugin插件是需要依赖puppeteer的,也就是谷歌出品的无头浏览器插件,这个插件会下载最新版的chromium(大约200M+);解决: npm install puppeteer --save;

2.预加载打包之后页面是静态页面,点击跳转页面无法跳转,没有加载js;所以要在最外层router-view外包一层 “< div id=“app”>”
在这里插入图片描述
3.点击跳转页面如果是新打开的页面,css js 等资源会加载不到,需要将 “assetsPublicPath: ‘./’”, 改为 “assetsPublicPath: ‘/’”,“/”是根目录(当前域名),“./”是当前目录(浏览器当前地址);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
要将Vue项目改为使用prerender-spa-plugin,需要进行以下步骤: 1. 安装prerender-spa-plugin插件: ``` npm install prerender-spa-plugin --save-dev ``` 2. 在webpack配置文件中引入插件: ``` const PrerenderSPAPlugin = require('prerender-spa-plugin'); ``` 3. 在plugins数组中添加插件配置: ``` plugins: [ new PrerenderSPAPlugin({ staticDir: path.join(__dirname, 'dist'), routes: ['/', '/about', '/contact'], // 可选项,生成的文件存储的路径,默认为 `./prerendered` outputDir: path.join(__dirname, 'prerendered'), // 可选项,生成文件的后缀名,默认为 `.html` postProcess (renderedRoute) { // 对渲染后的路由文件进行额外处理 } }) ] ``` 4. 在`package.json`文件中添加一个脚本: ``` "scripts": { "prerender": "npm run build && node prerender.js" } ``` 5. 创建一个名为`prerender.js`的文件,并添加以下代码: ``` const path = require('path'); const PrerenderSPAPlugin = require('prerender-spa-plugin'); const rendererPath = path.join(__dirname, 'dist', 'server', 'bundle.js'); const renderer = require(rendererPath); const options = { staticDir: path.join(__dirname, 'dist'), routes: ['/'], renderer: new PrerenderSPAPlugin.PuppeteerRenderer({ renderAfterDocumentEvent: 'render-event', headless: true, args: ['--no-sandbox', '--disable-setuid-sandbox'], }), }; const prerenderer = new PrerenderSPAPlugin(options); prerenderer .initialize() .then(() => { return prerenderer.renderRoutes(['/']); }) .then((renderedRoutes) => { console.log('Prerendering successful!'); console.log(renderedRoutes); }) .catch((error) => { console.error('Prerendering failed:'); console.error(error); }); ``` 6. 运行`npm run prerender`命令,生成预渲染文件。 以上就是将Vue项目改为使用prerender-spa-plugin的步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值