基于vue-cli npm run build之后vendor.js文件过大的解决方法


Posted in Javascript onSeptember 27, 2018

问题

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

解决方案

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

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

<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

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

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

2018.01.27补充

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

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

cnpm install --save-dev compression-webpack-plugin

2.设置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

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

以上这篇基于vue-cli npm run build之后vendor.js文件过大的解决方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
ajax 文件上传应用简单实现
Mar 03 Javascript
JavaScript 事件的一些重要说明
Oct 25 Javascript
js获取浏览器的可视区域尺寸的实现代码
Nov 30 Javascript
yepnope.js使用详解及示例分享
Jun 23 Javascript
JS实现在状态栏显示打字效果完整实例
Nov 02 Javascript
深入理解JS正则表达式---分组
Jul 18 Javascript
JS 对java返回的json格式的数据处理方法
Dec 05 Javascript
vue多页面开发和打包正确处理方法
Apr 20 Javascript
node 使用 async 控制并发的方法
May 07 Javascript
JS/HTML5游戏常用算法之碰撞检测 包围盒检测算法详解【凹多边形的分离轴检测算法】
Dec 13 Javascript
JavaScript使用prototype属性实现继承操作示例
May 22 Javascript
解决Vue + Echarts 使用markLine标线(precision精度问题)
Jul 20 Javascript
vue-cli的工程模板与构建工具详解
Sep 27 #Javascript
Vue项目查看当前使用的elementUI版本的方法
Sep 27 #Javascript
详解如何用VUE写一个多用模态框组件模版
Sep 27 #Javascript
解决vue项目nginx部署到非根目录下刷新空白的问题
Sep 27 #Javascript
vue上传图片到oss的方法示例(图片带有删除功能)
Sep 27 #Javascript
浅谈vue项目4rs vue-router上线后history模式遇到的坑
Sep 27 #Javascript
详解关于vue2.0工程发布上线操作步骤
Sep 27 #Javascript
You might like
Windows下的PHP5.0安装配制详解
2006/09/05 PHP
PHP之数组学习
2011/05/29 PHP
关于mysql字符集设置了character_set_client=binary 在gbk情况下会出现表描述是乱码的情况
2013/01/06 PHP
php预定义变量使用帮助(带实例)
2013/10/30 PHP
php远程下载类分享
2016/04/13 PHP
php preg_match的匹配不同国家语言实例
2016/12/29 PHP
自动更新作用
2006/10/08 Javascript
js 加载并解析XML字符串的代码
2009/12/13 Javascript
jQuery Jcrop插件实现图片选取功能
2011/11/23 Javascript
javascript动态的改变IFrame的高度实现自动伸展
2013/10/12 Javascript
Javascript基础教程之数组 array
2015/01/18 Javascript
第十章之巨幕页头缩略图与警告框组件
2016/04/25 Javascript
原生JS实现网络彩票投注效果
2016/09/25 Javascript
AngularJS ng-template寄宿方式用法分析
2016/11/07 Javascript
JavaScript中this的用法实例分析
2016/12/19 Javascript
JavaScript编写一个贪吃蛇游戏
2017/03/09 Javascript
微信小程序自定义音乐进度条的实例代码
2018/08/28 Javascript
JavaScript两种计时器的实例讲解
2019/01/31 Javascript
Vue模板语法中数据绑定的实例代码
2019/05/17 Javascript
Python是编译运行的验证方法
2015/01/30 Python
利用Python脚本生成sitemap.xml的实现方法
2017/01/31 Python
python使用正则表达式替换匹配成功的组并输出替换的次数
2017/11/22 Python
Python数据集切分实例
2018/12/08 Python
利用Tensorboard绘制网络识别准确率和loss曲线实例
2020/02/15 Python
浅谈python元素如何去重,去重后如何保持原来元素的顺序不变
2020/02/28 Python
pyecharts在数据可视化中的应用详解
2020/06/08 Python
python中pandas库中DataFrame对行和列的操作使用方法示例
2020/06/14 Python
澳大利亚拥有最佳跳伞降落点和最好服务的跳伞项目运营商:Skydive Australia
2018/03/05 全球购物
个人自荐信
2013/12/05 职场文书
开展党的群众路线教育实践活动方案
2014/02/05 职场文书
厂长岗位职责
2014/02/19 职场文书
学生上课看漫画的检讨书
2014/09/26 职场文书
2014年企业员工工作总结
2014/12/09 职场文书
公积金贷款承诺书
2015/04/30 职场文书
培根随笔读书笔记
2015/07/01 职场文书
Nginx域名转发https访问的实现
2021/03/31 Servers