您的位置:首页 > Web前端 > Vue.js

解决vue-cli npm run build之后vendor.js文件过大的问题(打包优化)

2018-08-27 10:44 1471 查看

https://www.geek-share.com/detail/2722313354.html

问题

      vue-cli 

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

解决方案

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

      1.在项目根目录index.html使用cdn节点导入

[code]<div id="app"></div>
<!-- 先引入 Vue -->
<!--开发环境-->
<script src="https://cdn.bootcss.com/vue/2.5.3/vue.js"></script>
<!--生产环境-->
<!--<script src="https://cdn.bootcss.com/vue/2.5.3/vue.min.js"></script>-->
<!-- 引入组件库 -->
<script src="https://cdn.bootcss.com/axios/0.17.1/axios.min.js"></script>
<script src="https://cdn.bootcss.com/element-ui/1.4.10/index.js"></script>

      2.项目根目录下

build/webpack.base.config.js
中添加
externals

[code]externals: {
vue: 'Vue',
'element': 'element-ui',
'axios':'axios',
},

      3.

main.js
import ... from ...
就可以去掉了,若没去掉webpack还是会把对应的依赖进行打包。

2018.01.27补充

      在项目

config/index.js
中可以开启gzip压缩,对打包优化也有很大的帮助

      1.首先安装插件 compression-webpack-plugin

[code]cnpm install --save-dev compression-webpack-plugin

      2.设置

productionGzip: true

[code]    // 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

      3.

npm run build
执行后会发现每个js和css文件会压缩一个gz后缀的文件夹,浏览器如果支持g-zip 会自动查找有没有gz文件 找到了就加载gz然后本地解压 执行。

阅读更多
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: