纯JS实现zip打包文件并下载zip打包文件并下载功能对大家来说并不陌生,正好最近在做一个影像项目遇到类似需求,所以我也折腾一下,希望对需要的小伙伴有帮助。如何实现ZIP打包下载?通过搜索找到这个,不知道大家遇到过没,我是使用jszip这个项目实现的:https://github.com/Stuk/jszip,压缩和未压缩的JS文件都在dist目录下,大家自行下载。如何使用:1.引入我们需要的js2.执行打包与下载下面是官方示意代码,我加上了更详细的注释:// 初始化一个zip打包对象var zip = new JSZip();// 创建一个被用来打包的名为Hello.txt的文件zip.file("Hello.txt", "Hello World\n");// 创建一个名为images的新的文件目录var img = zip.folder("images");// 这个images文件目录中创建一个base64数据为imgData的图像,图像名是smile.gifimg.file("smile.gif", imgData, {base64: true});// 把打包内容异步转成blob二进制格式zip.generateAsync({type:"blob"}).then(function(content) { // content就是blob数据,这里以example.zip名称下载 // 使用了FileSaver.js saveAs(content, "example.zip");});/*最终下载的zip文件包含内容如下:Hello.txtimages/ smile.gif*/使用非常简单,官方示意也通俗易懂,我直接照着改改效果就出来了。其中,提到了一个FileSaver.js,这也是非常有名的项目,可以介绍一下。下载FileSaver.jsFileSaver.js项目地址是:https://github.com/eligrey/FileSaver.js/压缩和未压缩的JS文件也是在dist目录下,大家自行下载。使用示意:FileSaver.js非常强,不仅兼容到IE10+,而且还支持大文件下载,Chrome浏览器下甚至可以下载2GB大小的文件。FileSaver.js搭配js-xlsx还可以纯前端下载Excel文件。如果是生成DOC文件,试试这个项目。jszip使用示意以下来源于张鑫旭老师方法我的需求是把一堆SVG文件打包下载,已经有SVG代码和id数据(可以作为文件名)。由于我的下载功能不需要兼容IE浏览器,因此,直接使用了元素下载,基于HTML5 download属性。于是有如下代码:// data是个数组// 数组项结构 {id: "icon-xxx", svgHTML: "