Vue-CLI路由懒加载预渲染项目实战

常见的 Vue单页SPA构建之后的index.html只是一个包含根节点的空白页面,当所有需要的js加载完毕之后,才会开始解析并创建 vnode,然后再渲染出真实的DOM。当这些js文件过大而网速又很慢或者出现意料之外的报错时,就会出现所谓的白屏。

而且单页SPA还有一个很大的弊端就是对SEO很不友好。那么如何解决这些问题呢?

SSR(Nuxt)--当然是很好的解决方案,但这也意味着一定的学习成本和运维成本,而如果你已经有了一个现成的Vue单页应用,转向SSR也并不是一个无缝的过程,需要投入更大的学习成本去开发。

那么预渲染就显得更加合适了。只需要安装一个Webpack的插件+一些简单的Webpack配置就可以解决上述的两个问题。

项目实战预览

用手机预览效果更佳(PC端请用手机调试模式)

没有预渲染:

预览地址:http:fancy.czero.cn

Github:github.com/czero1995/f…

打包完成的项目结构:

有预渲染:

预览地址:http:router.czero.cn

Github:github.com/czero1995/f…

打包完成的项目结构:

查看源码: 经过prerender预渲染过后的代码:

将Vue-cli单页SPA转为预渲染

1.需要将router设为history模式。

2.修改服务器nginx的配置(刷新页面的时候会做重定向跳转)

try_files $uri /index.html;
复制代码

提个醒:如下图,这里有个大坑,当需要用懒加载来做预渲染,nginx上配置 try_files uriuri/ /index.html;

没在首页刷新页面的时候,会报错。

3.安装prerender-spa-plugin

cnpm install prerender-spa-plugin --save
复制代码

4.修改build/webpack.prod.conf.js下的配置为:

5.将config/index.js里的build中的assetsPublicPath字段设置为'/'

6.调整main.js

new Vue({
  i18n,
  router,
  store,
  render: h => h(App)
}).$mount('#app', true)
复制代码

7.执行npm run build你会发现,最后打包出来的目录和之前不太一样,都是一些渲染完成好的页面

加持vue-meta-info提高SEO

npm install vue-meta-info --save
复制代码

全局引入 vue-meta-info

import Vue from 'vue'
import MetaInfo from 'vue-meta-info'

Vue.use(MetaInfo)
复制代码

组件内静态使用 metaInfo

  export default {
    metaInfo: {
      title: 'My Example App', // set a title
      meta: [{                 // set meta
        name: 'keyWords',
        content: 'My Example App'
      }]
      link: [{                 // set link
        rel: 'asstes',
        href: 'https://assets-cdn.github.com/'
      }]
    }
  }
复制代码

Github

无预渲染:github.com/czero1995/f…

有预渲染:github.com/czero1995/f…

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值