vue-cli build vendor.js 过大

vue-cli npm run build命令默认把dependencies中的依赖统一打包,导致vendor.js文件过大,出现首屏加载过于缓慢的问题。

解决方案:

首先,vue、axios、element-ui这些基本上不会改变的依赖我们可以把它们用cdn导入,没有必要打包到vendor.js中。

在根目录下的index.html中使用cdn节点导入这些js

<div id="app"></div>
<!-- 先引入 Vue -->
<script src="https://cdn.bootcss.com/vue/2.5.17-beta.0/vue.min.js"></script>
<!-- 引入组件库 -->
<script src="https://cdn.bootcss.com/axios/0.18.0/axios.min.js"></script>
<script src="https://unpkg.com/element-ui/lib/index.js"></script>

然后,在项目根目录下build/webpack.base.config.js中的module.exports添加externals

module.exports = {
    externals: {  
          vue: 'Vue',    
         'element': 'element-ui', 
         'axios':'axios',  
   },
}

接着,把根目录下src/main.js 中vue、element和axios 的import ... from...去掉,若没有删除webpack还是会把对应的依赖进行打包。

最后就是开启gzip压缩,在项目根目录下的config/index.js中可以开启gzip压缩,对打包优化也有很大的帮助

先安装插件compression-webpack-plugin

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

然后进入根目录下的config/index.js,把productionGzip改为true。

    // Gzip off by default as many popular static hosts such as
    // Surge or Netlify already gzip all static assets for you.
    // Before setting to `true`, make sure to:
    // npm install --save-dev compression-webpack-plugin
    productionGzip: true,
    productionGzipExtensions: ['js', 'css'],

    // Run the build command with an extra argument to
    // View the bundle analyzer report after build finishes:
    // `npm run build --report`
    // Set to `true` or `false` to always turn it on or off
    bundleAnalyzerReport: process.env.npm_config_report
之后 npm run build 执行后会发现每个js和css文件会压缩一个gz后缀的文件夹,浏览器如果支持g-zip 会自动查找有没有gz文件 找到了就加载gz然后本地解压 执行。

猜你喜欢

转载自blog.csdn.net/qq_33294309/article/details/80926387
今日推荐