前言
上文讲到一个 vue-cli
带脚本生成内容的老项目的打包时间已经从 40min
,优化到 12min
,再到 9min
。
还有可以考虑的方式包含缩小脚本体积、依赖分包、构建的缓存等等。
那么本文就来讨论缩小脚本体积的方式。
分析
前文已知,生成的大量的脚本内容都是JSON
的格式。
众所周知,JSON
格式是一种 key-value
的格式,这样的格式,在遇到大量的描述内容时,势必会遇到 key
不断重复的问题,这就造成了文件体积迅速膨胀,尤其是在大量的数组,仅 value
不一样的时候。
所以,JSON
的格式一定有极大的压缩空间,尤其是我当前所遇到的场景,至少有50%以上的体积可以被压缩掉。
当然本文就不讨论具体的压缩方法了,直接上网查库解决问题。
当前生成文件的大小:
当前打包时间:
对压缩库的要求
首先,能够在前端js
环境和 nodejs
环境中直接压缩和解压缩使用,这是必须满足的。
其次,压缩率要尽量高,压缩后的内容不必一定要可读,二进制都行。
然后,一定要无损压缩,解压后不影响后续的使用。
逛了一圈后选中了 compress-json
库。
github:github.com/beenotung/c…
该库不仅可以在js中使用,还有PHP、Python等版本。
使用压缩库
安装
yarn add compress-json
压缩脚本
const json = process.argv[2]
const compressedJson = require('compress-json').compress(JSON.parse(json))
console.log(JSON.stringify(compressedJson))
修改生成文件的命令
citem=$(node compress.js "${item}")
echo "import { decompress } from 'compress-json';export const ${uuid} = decompress(`${citem}`)" > "${filename}.js"
对比效果
压缩后的文件大小
压缩后的打包时长
我们可以看到打包时长略有缩短,不是特别明显,说明体积对打包时长的影响不算特别大。
当然,体积小肯定不只是这里的作用,构建产物的体积变小了,对整个项目的访问无疑是好处巨大的。
大胆猜测一下,在之前的优化中,已经将 JSON
内容修改为了字符串的形式,对于编译过程来说,这些内容几乎已经原样输出,如果这样的话,压缩过后,在本地尤其磁盘速度和cpu都比较空闲的时候,对打包的时长影响不会很大。
写在最后
虽然本次优化的结果在本地打包时不是特别明显,但是显著减小了构建产物的大小。
最后本次修改放到了 Jenkins
打包脚本中,打包时间减少到了 7min
,已经快接近正常的打包时长。
当然,接下来还可以继续考虑构建分包,构建缓存等等方案。
– 欢迎点赞、关注、转发、收藏【我码玄黄】,各大平台同名。
1、本站所有资源均从互联网上收集整理而来,仅供学习交流之用,因此不包含技术服务请大家谅解!
2、本站不提供任何实质性的付费和支付资源,所有需要积分下载的资源均为网站运营赞助费用或者线下劳务费用!
3、本站所有资源仅用于学习及研究使用,您必须在下载后的24小时内删除所下载资源,切勿用于商业用途,否则由此引发的法律纠纷及连带责任本站和发布者概不承担!
4、本站站内提供的所有可下载资源,本站保证未做任何负面改动(不包含修复bug和完善功能等正面优化或二次开发),但本站不保证资源的准确性、安全性和完整性,用户下载后自行斟酌,我们以交流学习为目的,并不是所有的源码都100%无错或无bug!如有链接无法下载、失效或广告,请联系客服处理!
5、本站资源除标明原创外均来自网络整理,版权归原作者或本站特约原创作者所有,如侵犯到您的合法权益,请立即告知本站,本站将及时予与删除并致以最深的歉意!
6、如果您也有好的资源或教程,您可以投稿发布,成功分享后有站币奖励和额外收入!
7、如果您喜欢该资源,请支持官方正版资源,以得到更好的正版服务!
8、请您认真阅读上述内容,注册本站用户或下载本站资源即您同意上述内容!
原文链接:https://www.shuli.cc/?p=21155,转载请注明出处。
评论0