vue prerender-spa-plugin 预渲染解决seo问题

//vue.config.js
const path = require('path');
const PrerenderSPAPlugin = require('prerender-spa-plugin');
const Renderer = PrerenderSPAPlugin.PuppeteerRenderer;
 
configureWebpack: config => {
    if (process.env.NODE_ENV === 'production') {
      console.log(process.env.NODE_ENV)
      return {
       plugins: [
        new PrerenderSPAPlugin({
          //要求-给的WebPack-输出应用程序的路径预渲染。
          staticDir: path.join(__dirname, './dist'),
          //必需,要渲染的路线。
          routes: ['/productDetail'],
          //必须,要使用的实际渲染器,没有则不能预编译
          renderer: new Renderer({
           inject: {
            foo: 'bar'
           },
           headless: false, //渲染时显示浏览器窗口。对调试很有用。
           //等待渲染,直到检测到指定元素。
           //例如,在项目入口使用`document.dispatchEvent(new Event('custom-render-trigger'))`
          //  renderAfterDocumentEvent: "render-event",
          //  renderAfterTime: 5000
          })
         })
       ]
      }
     } else {
      return;
     }
  },
//main.js
new Vue({
  router,
  store,
  render: (h) => h(App),
  mounted() {
    // document.dispatchEvent(new Event('render-event'))
    document.dispatchEvent(new Event('custom-render-trigger')) #这里是重点
   }
}).$mount('#app');

PS:踩坑

1、路由页面前两个页面不能有懒加载。

2、cnpm i --save puppeteer 这个运行完第一步命令后再运行下此命令,容易安装失败;([prerender-spa-plugin] Unable to prerender all routes! 我是为了解决这个报错问题,每个人问题可能不一样,其它问题我没遇到,需要大家自己搜索解决)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值