有时候我们将vue项目打包后运行后,访问首页时发现:需要等待十几秒甚至几十秒的时间才能看到页面,通过F12发现,vendor.js高达几MB,加载时间很长,这给我们造成了极大的困扰,用户体验太差了吧!

下面我就来为大家介绍一下,有效的解决方法:


文章目录

  • 1. CDN方式引入各种包
  • 第一步:在index.html文件中用CDN方式引入所需的包,如下图所示:
  • 第二步:把通过CDN方式引入的包,注释掉import引入
  • 第三步:在webpack中设置打包忽略vue/vuex/vue-router等包
  • 第四步:打包
  • 2. 路由懒加载的方式加载路由
  • 3. webpack启用gzip压缩
  • 第一步:首先安装插件
  • 第二步:在config/index.js文件中打开Gzip开关,配置需要压缩的文件扩展名
  • 第三步:webpack.prod.conf.js中设置具体压缩配置项
  • 总结


1. CDN方式引入各种包

下面我就以vuevuexvue-routeraxioselement-uiecharts为例,为大家详细示范如何通过CDN引入这些包

第一步:在index.html文件中用CDN方式引入所需的包,如下图所示:

(这里推荐大家两个常用的、比较稳定的CDN网站:https://www.bootcdn.cn、https://www.jsdelivr.com)

index.html

elementor无法加载_javascript


附上link代码:

<!-- 引入样式 -->
  <link href="https://cdn.bootcss.com/element-ui/2.8.2/theme-chalk/index.css" rel="stylesheet">

附上script 代码:

<script src="https://cdn.bootcss.com/vue/2.5.16/vue.min.js"></script>
  <script src="https://cdn.bootcss.com/element-ui/2.8.2/index.js"></script>
  <script src="https://cdn.bootcss.com/vue-router/3.0.1/vue-router.min.js"></script>
  <script src="https://cdn.bootcss.com/vuex/3.0.1/vuex.min.js"></script>
  <script src="https://cdn.bootcss.com/axios/0.17.0/axios.min.js"></script>
  <script src="https://cdn.bootcss.com/echarts/4.4.0-rc.1/echarts.min.js"></script>
  <script src="https://cdn.bootcss.com/echarts/4.4.0-rc.1/echarts.common.min.js"></script>

第二步:把通过CDN方式引入的包,注释掉import引入

这里有个坑,需要注意一下:
除了Vue.use(Element)需要注释以外( 如果加上这句话,还是会打包element-ui到vendor.js文件中),Vue.prototype.axios = axiosVue.use(VueRoter)Vue.use(vuex)等依然要使用。

main.js

elementor无法加载_webpack_02


router/index.js

这里要注意一下,Vue.use(VueRouter)中的VueRouter不能改为其他字段,否则会报错
这里我本来引入的时候命名为Router,注释掉后就将Vue.use(Router)改为了Vue.use(VueRouter)

elementor无法加载_webpack_03


store/index.js

elementor无法加载_webpack_04


utils/httpRequest.js

elementor无法加载_vue_05

按上图所示方法,注释掉其他import引入的地方即可

第三步:在webpack中设置打包忽略vue/vuex/vue-router等包

webpack.base.conf.js

externals对象中输入的属性,表示这些包是通过外部引入的,不需要将它们打包到vendor.js

elementor无法加载_vue_06


附上代码:

// 引入外部库, 无需webpack打包处理
  externals: {
    'vue' : 'Vue',
    'vue-router':'VueRouter',
    'vuex':'Vuex',
    'axios':'axios',
    'element-ui':'ElementUI',
    'mockjs': 'Mock',
    'echarts': 'echarts',
    'ueditor': 'UE'
  }

第四步:打包

至此我们就完成了CDN引入包的方式,现在赶紧打包一下看看效果吧

2. 路由懒加载的方式加载路由

elementor无法加载_vue_07

3. webpack启用gzip压缩

我们一般会在构建时压缩
webpack的compression-webpack-plugin插件用于支持构建项目时压缩文件,具体配置如下:

第一步:首先安装插件

npm install --save-dev compression-webpack-plugin

第二步:在config/index.js文件中打开Gzip开关,配置需要压缩的文件扩展名

config/index.js

(webpack相关)

elementor无法加载_vue_08

第三步:webpack.prod.conf.js中设置具体压缩配置项

webpack.prod.conf.js

elementor无法加载_webpack_09


附上代码:

(这里其实会自动生成)

if (config.build.productionGzip) {
  const CompressionWebpackPlugin = require('compression-webpack-plugin')

  webpackConfig.plugins.push(
    new CompressionWebpackPlugin({
      asset: '[path].gz[query]',
      algorithm: 'gzip',
      test: new RegExp(
        '\\.(' +
        config.build.productionGzipExtensions.join('|') +
        ')$'
      ),
      threshold: 10240,
      minRatio: 0.8
    })
  )
}

打包后会同时保留原文件和压缩后的文件,接下的事情就交给后端了,让他们服务端nginx启动gzip_static

更加详细的关于webpack配置Gzip的教程可以参考这篇文章

总结

以上就是我为大家整理的可以有效解决由打包后的vendor.js文件过大问题引起的vue首屏加载慢的方法,如果有什么不足或者错误的地方,还请指教,及时修改,谢谢大家。