vue项目打包优化之CDN和路由懒加载

路由懒加载

一.前言
当打包构建应用时,JavaScript 包会变得非常大,影响页面加载。如果我们能把不同路由对应的组件分割成不同的代码块,然后当路由被访问的时候才加载对应组件,这样就更加高效了。
让组件按需加载

1.修改 router/index.js 中导入组件的语法
在这里插入图片描述
2 **修改 /build/webpack.prod.conf.js 中的chunkFilename
vue项目打包优化之CDN和路由懒加载_第1张图片

CDN优化第三包的加载

在Vue项目中,引入到第三方包的所有js、css文件,编译时都会被打包进vendor.js,浏览器在加载该文件之后才能开始显示首屏。若是引入的库众多,那么vendor.js文件体积将会相当的大,影响首开的体验。

解决方法是,将引用的外部js、css文件剥离开来,不编译到vendor.js中,而是用资源的形式引用,这样浏览器可以使用多个线程异步将vendor.js、外部的js等加载下来,达到加速首开的目的。

外部的库文件,可以使用CDN资源,或者别的服务器资源等。

下面,以引入vue、vuex、vue-router为例,说明处理流程。

一. 在 index.html 中引入CDN提供的JS文件
提供个快速查找cdn网址: https://www.bootcdn.cn/

vue项目打包优化之CDN和路由懒加载_第2张图片
2. 在 /build/webpack.base.conf.js 中添加配置 externals对象(vue-cli2中)
vue项目打包优化之CDN和路由懒加载_第3张图片
vue表示 import Vue form vue
Vue表示的全局变量中的Vue
import vue from Vue不会在去node_modules中加载vue

 externals: {
    vue: 'Vue',
    'vue-router': 'VueRouter',
    axios: 'axios',
    'element-ui': 'ELEMENT',
    moment: 'moment',
    'vue-quill-editor': 'VueQuillEditor'
  },

**

3.在vuel-cli3中需要这样配置

**
vue项目打包优化之CDN和路由懒加载_第4张图片
注意:像vue-router这种峰值写法,key值需要加双引号

3.在main.js中就可以注释掉引入的css
注意**:通过CDN引入 element-ui 的样式文件后,就不需要在 main.js 中导入 element-ui 的CSS文件了。所以,直接注释掉 main.js 中的导入 element-ui 样式即可,(但是全局的vue,axios这些在组件会被使用,不能被注释
vue项目打包优化之CDN和路由懒加载_第5张图片
4.这时你会发现打包后vendor.js的比之前cdn没优化之前小了很多

你可能感兴趣的:(vue项目打包优化之CDN和路由懒加载)