Vue中将多个图片下载打包成zip格式

效果:
1680745307968.png

npm install jszip
npm install file-saver

import JSZip from "jszip";
import FileSaver from "file-saver";

BatchDownload(){
       const imgDataUrl = [
          {
            nickname: '小王.jpg',
            path: 'https://xxx.jpg'
          },
          {
            nickname: '小张.jpg',
            path: 'https://xxx.jpg'
          }
        ]
        let _this = this;
        let zip = new JSZip();
        let cache = {};
        let promises = [];
        _this.title = '正在加载压缩文件';
 
        for (let item of imgDataUrl) {
          const promise= _this.getImgArrayBuffer(item.path).then(data => {
            // 下载文件, 并存成ArrayBuffer对象(blob)
            zip.file(item.nickname, data, { binary: true }); // 逐个添加文件
            cache[item.nickname] = data;
          });
          promises.push(promise);
        }
 
        Promise.all(promises).then(() => {
          zip.generateAsync({ type: "blob" }).then(content => {
            _this.title = '正在压缩';
            // 生成二进制流
            FileSaver.saveAs(content, '签到照片'); // 利用file-saver保存文件  自定义文件名
            _this.title = '压缩完成';
          });
        }).catch(res=>{
          _this.$message.error('文件压缩失败');
        });
      })
},
//通过url 转为blob格式的数据
    getImgArrayBuffer(url){
      let _this=this;
      return new Promise((resolve, reject) => {
        //通过请求获取文件blob格式
        let xmlhttp = new XMLHttpRequest();
        xmlhttp.open("GET", url, true);
        xmlhttp.responseType = "blob";
        xmlhttp.onload = function () {
          if (this.status == 200) {
            resolve(this.response);
          }else{
            reject(this.status);
          }
        }
        xmlhttp.send();
      });
    },
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容