解决vue-cli webpack打包开启Gzip 报错问题


Posted in Javascript onJuly 24, 2019

前两天项目上线,用vue-cli npm run build命令打包,打包完成后我擦吓了一跳,15M。本来暂时不打算优化的,但是每次看着部署包这么大,想想还是先优化一下,让包好看点,免得以后出现心理阴影!

在把 map文件干掉后,发现webpack这打包的速度,也忒感人了。在进行不自动生成 map文件设置时,有看到webpack自带的productionGzip功能,索性就一次性一起鼓捣鼓捣。

下面是瞎鼓捣历程,差点就鼓捣不出来了。

1、在项目 根目录config/index.js中build内找到productionGzip: false,把false改为true。与 productionSourceMap 刚好相反。

解决vue-cli webpack打包开启Gzip 报错问题

属性值修改后,这个时候可以执行 npm run build。但是会报错,提示找不到 "Cannot find module 'compression-webpack-plugin'"

解决vue-cli webpack打包开启Gzip 报错问题

2、也就是说需要安装依赖compression-webpack-plugin 官方推荐的命令是:(但是网不好的话就凉凉了)

npm install --save-dev compression-webpack-plugin //在没有给定版本号时该命令默认安装最新版compression-webpack-plugin,问题恰恰就出在这

安装完成以后,重新运行 npm run build,然后悲剧了:

解决vue-cli webpack打包开启Gzip 报错问题

从报错显示获知,是配置选项验证失败,但是是哪一项验证失败,或者那些项验证失败就不晓得了,打开报错日志,越看越蒙圈了,一脸茫然。从源代码里面也没看出个所以然。

解决vue-cli webpack打包开启Gzip 报错问题

从校验参数来看,参数就两个,但是第一个参数内属性很多。

解决vue-cli webpack打包开启Gzip 报错问题,从结果看是这行代码里面执行的校验失败了。至于这行代码执行的什么,水平不够查不下去了。

最后没得法了,只能去官网 https://www.npmjs.com/package/compression-webpack-plugin上看看,有么得啥突破。进去第一眼就瞄到了 2.0.0•Public•Published3 months ago,一下就感觉有点不对了,一般小版本的更新都是 1.xx.xx,很少这种直接全零的,全零的一般适用于大版本的升级更新,再看看上面的配置项检验失败,选项属性匹配不上。突然有种莫名被坑的感觉。接着看下面的介绍和文档,①先对应了下node的版本 node@v8.11.3,还在匹配的范围内。② Requirements:This module requires a minimum of Node v6.9.0 and Webpack v4.0.0 (此模块最低需要 Nodev6.9.0和Webpack v4.0.0),我这webpack版本明显差一大截。这下总算找到症结所在了。

解决vue-cli webpack打包开启Gzip 报错问题

解决vue-cli webpack打包开启Gzip 报错问题

解决vue-cli webpack打包开启Gzip 报错问题

3、找到症结所在,那处理起来就简单了。既然最新版本太高,在用的webpack高攀不起,那就只能给它降级了,木得法。

①卸载已经安装的最新版2.0compression-webpack-plugin安装包。

npm uninstall --save-dev compression-webpack-plugin

② 重新安装1.1.12版本(该版本为1.1的最新版)。卸载其实可以不用,直接执行安装命令,进行版本覆盖也行。

npm install --save-dev compression-webpack-plugin@1.1.12
//记得带版本号

③等安装好之后,重新执行 npm run build 进行打包,终于成功了,真他妈艰难!

安装过程中,还遇到另外一个问题。网速和墙的问题:

解决vue-cli webpack打包开启Gzip 报错问题

这个倒是好解决,使用淘宝镜像 就行。 安装过程以及可能出现的问题和解决 可以移步https://3water.com/article/166090.htm进行参考!

总结

以上所述是小编给大家介绍的解决vue-cli webpack打包开启Gzip 报错问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
input 和 textarea 输入框最大文字限制的jquery插件
Oct 27 Javascript
jQuery回调函数的定义及用法实例
Dec 23 Javascript
javascript获取当前鼠标坐标的方法
Jan 10 Javascript
javascript实现类似百度分享功能的方法
Jul 27 Javascript
JS+CSS实现美化的下拉列表框效果
Aug 11 Javascript
JavaScript的字符串方法汇总
Jul 31 Javascript
浅谈javascript的闭包
Jan 23 Javascript
基于AngularJS实现表单验证功能
Jul 28 Javascript
input type=file 选择图片并且实现预览效果的实例
Oct 26 Javascript
vue不操作dom实现图片轮播的示例代码
Dec 18 Javascript
js利用拖放实现添加删除
Aug 27 Javascript
antd-DatePicker组件获取时间值,及相关设置方式
Oct 27 Javascript
Vue  webpack 项目自动打包压缩成zip文件的方法
Jul 24 #Javascript
JavaScript面向对象中接口实现方法详解
Jul 24 #Javascript
IE11下处理Promise及Vue的单项数据流问题
Jul 24 #Javascript
微信小程序如何引用外部js,外部样式,公共页面模板
Jul 23 #Javascript
详解Vue中的基本语法和常用指令
Jul 23 #Javascript
js如何获取访问IP、地区、当前操作浏览器
Jul 23 #Javascript
node.js express框架简介与实现
Jul 23 #Javascript
You might like
咖啡常见的种类
2021/03/03 新手入门
又一个php 分页类实现代码
2009/12/03 PHP
深入理解PHP中的Session和Cookie
2013/06/21 PHP
php获取是星期几的的一些常用姿势
2019/12/15 PHP
基于jQuery的的一个隔行变色,鼠标移动变色的小插件
2010/07/06 Javascript
再论Javascript的类继承
2011/03/05 Javascript
Node.js编程中客户端Session的使用详解
2015/06/23 Javascript
jQuery unbind 删除绑定事件详解
2016/05/24 Javascript
实现一个完整的Node.js RESTful API的示例
2017/09/29 Javascript
vue.js语法及常用指令
2017/10/29 Javascript
vue项目中跳转到外部链接的实例讲解
2018/09/20 Javascript
详解多页应用 Webpack4 配置优化与踩坑记录
2018/10/16 Javascript
微信小程序--特定区域滚动到顶部时固定的方法
2019/04/28 Javascript
jquery+ajax实现上传图片并显示上传进度功能【附php后台接收】
2019/06/06 jQuery
java遇到微信小程序 "支付验证签名失败" 问题解决
2019/12/22 Javascript
阿望教你用vue写扫雷小游戏
2020/01/20 Javascript
原生javascript制作的拼图游戏实现方法详解
2020/02/23 Javascript
python的即时标记项目练习笔记
2014/09/18 Python
深入解析Python中的list列表及其切片和迭代操作
2016/03/13 Python
实例解析Python中的__new__特殊方法
2016/06/02 Python
python如何让类支持比较运算
2018/03/20 Python
Python实现输出某区间范围内全部素数的方法
2018/05/02 Python
django连接mysql配置方法总结(推荐)
2018/08/18 Python
初次部署django+gunicorn+nginx的方法步骤
2019/09/11 Python
TensorFlow 输出checkpoint 中的变量名与变量值方式
2020/02/11 Python
Django如何在不停机的情况下创建索引
2020/08/02 Python
任意存:BOXFUL
2018/05/21 全球购物
兰蔻俄罗斯官方网站:Lancome俄罗斯
2019/12/09 全球购物
德尔福集团DELPHI的笔试题
2012/02/22 面试题
大学生个人简历自我评价
2013/11/16 职场文书
给校长的建议书200字
2014/05/16 职场文书
财务会计专业自荐书
2014/06/30 职场文书
三月法制宣传月活动总结
2014/07/03 职场文书
四风问题个人剖析材料
2014/10/07 职场文书
Python insert() / append() 用法 Leetcode实战演示
2021/03/31 Python
php访问对象中的成员的实例方法
2021/11/17 PHP