业务中有时候需要获取某个 zip 压缩包内的文件内容展示到前端,在 zip 包体积不是那么大的时候(几MB、十几MB甚至几十MB)并且不涉及压缩包解密的时候,可以考虑纯前端方案。
前端使用Jszip解压zip
安装依赖: npm i jszip
请求 zip 文件并转为 Blob:
使用 jszip 解压 Blob:
这时候你会得到一个含有 files 列表数据的 zipData , 这个 files 就是压缩包中的文件列表,这时候的处理就有意思了,下面慢慢说。
如果你的压缩包里面不止一个文件怎么获取
基于上一步,我们拿到了 files 文件列表,这时候如果我们的压缩包里面有很多文件我们怎么全部都拿到呢?我们就需要递归这个列表了:
但是事情往往没有这么简单,比如压缩包里面还有压缩包怎么办呢?
嵌套压缩改咋处理
改良 extractNestedZip 方法:
我们现在解决了嵌套的问题。如果压缩包中有文件夹该怎么处理呢?尝试过你会发现如果是文件夹,在 files 中对应的数据就是空的,所以我们应该过滤这种情况:
压缩包中的文件夹要过滤
现在看了好像一切都没问题了,但是我们最终的文件怎么读到呢?
文本文件和二进制文件要分别处理
如果压缩包中只包含文本类的文件,比如 .json,.log之类的,就可以简单的用 file.async('text') 来获取文件内容,但是如果包含 .mp3,.png 就要注意了,我们接下来优化这些情况:
我们这里举了些例子,就是判断文件名以什么结尾,如果是常见的媒体格式,就转为 Blob,不然就转为字符串。这个方案就可以处理压缩包中不同格式的问题,最终我们就拿到了一个 name 是表示压缩包中文件名称,data 是对应文件内容的列表了。
总结
在业务中需要前端场景解压压缩包是比较少见的,但是如果有这类的场景我们就可以借助于 jszip 来做。这次分享的主要是拿到文件之后如何全部拿到压缩包的所有内容的技巧,大家如果有别的问题,欢迎评论区沟通。
以上就是JS前端解压zip的方法和技巧分享的详细内容,更多关于JS前端解压zip的资料请关注脚本之家其它相关文章!
上一篇:没有了