vue优化之CND优化

问题: vue 打包(npm run build)之后, vendor.js文件过大, 导致首页加载速度非常慢, 影响体验效果, 原因是第三方库(vue , vue-router , element-ui , axios )都打包在vendor.js 文件中

解决方法

使用 CND 优化
CND 优化是指把第三方库(vue , vue-router , element-ui , axios )通过外链的形式引入到项目目中, 减少打包时 vendor.js 文件的体积, 以加快页面访问速度

使用方法
  1. 在项目根目录中找到 index.html , 把需要用到的资源用过 CDN 的方式引入该文件中, 如图:
    推荐几个相对稳定的外链地址 bootcdn , staticfile, jsdelivr
    在这里插入图片描述
    如果担心cdn引入的外链出现问题, 可以使用两个不同的外链地址, 毕竟同事出现问题的几率还是比较小的
    在这里插入图片描述
    注: vue-router 引入两次页面会报错
    在这里插入图片描述
    原因: vue-router 加载两次时, 页面会有报错, 意思是vue-router 不能注册两次, 虽然正常使用, 但是页面报错还是需要解决一下
    解决办法: 方法1: vue-router 安装到本地, 方法二: vue-router只加载一次

若是担心cdn 不稳定, 则可以使用,静态资源加载的方法(即 当cdn加载失败的时候, 加载静态资源)
在这里插入图片描述

if (typeof Vue == 'undefined') {
  document.write(unescape("%3Cscript src='/static/js/vue/2.5.16/vue.min.js'%3E%3C/script%3E"))
}
if (typeof VueRouter == 'undefined') {
  document.write(unescape("%3Cscript src='/static/js/vue-router/3.0.1/vue-router.min.js'%3E%3C/script%3E"))
}
if (typeof Vuex == 'undefined') {
  document.write(unescape("%3Cscript src='/static/js/vuex/3.0.1/vuex.min.js'%3E%3C/script%3E"))      
}
if (typeof axios == 'undefined') {
  document.write(unescape("%3Cscript src='/static/js/axios/0.18.1/axios.min.js'%3E%3C/script%3E"))
}
  1. build/webpack.base.conf.js 文件中进行配置
    externals: {
    ‘vue’: ‘Vue’,
    ‘vue-router’: ‘VueRouter’,
    ‘element-ui’: ‘ELEMENT’,
    ‘axios’: ‘axios’
    },
    在这里插入图片描述
  2. 去掉引入的文件
    去掉import 引入
    去掉Vue.use(XXX)
    在这里插入图片描述
    使用 cdn外链后, npm run build 打包能明显的感觉到 vendor.js 变小很多, 页面相应速度也会变快
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值