批量导出成压缩包

downloadPort() {
      let imgName = "components";
      let zip = new jsZip();
      // 获取所有选中的DOM元素
      let doms = document.querySelectorAll('.selecteds');
      // 生成Promise数组,用来存储所有生成的canvas对象
      let allPromises = [];
      // 遍历每个选中的DOM元素
      for (let i = 0; i < doms.length; i++) {
        let promise = new Promise((resolve, reject) => {
          html2canvas(doms[i], {
            allowTaint: true,
            useCORS: true,
            tainttest: true,
            logging: true,
            backgroundColor: `#fff`,
          }).then((canvas) => {
            // 把每个生成的canvas对象存储到zip文件中
            canvas.toBlob(function(blob) {
              zip.file(`component${i + 1}.png`, blob);
              resolve();
            });
          });
        });
        allPromises.push(promise);
      }
      // 等待所有Promise对象完成后,生成并下载zip文件
      Promise.all(allPromises).then(() => {
        zip.generateAsync({ type: "blob" }).then(function (content) {
          saveAs(content, `${imgName}.zip`);
        });
      });
      // 清空选中的DOM元素
      this.$refs.table.clearSelection();
    },

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SKMA

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值