Vue 实现批量下载附件(JPG、PNG、PDF、EXCEL)打包压缩Zip包功能。

npm install jszip
npm install axios
import JSZip from "jszip";
import axios from "axios";

async batchXiaZzCli() {
this.batchLoading = true;
try {
// 创建一个JSZip实例
const zip = new JSZip();
// 循环下载文件并添加到压缩包中
for (let i = 0; i < this.checkedCities.length; i++) {
const response = await axios.get(this.checkedCities[i].reduceFileUrl, { responseType: "arraybuffer" });
// 获取文件名(如果文件名相同则只会下载一份,所以这里将名字加上了i)
const fileName = i + 1 + this.checkedCities[i].oldName;
// 将文件添加到压缩包中
zip.file(fileName, response.data);}
// 生成压缩包
const content = await zip.generateAsync({ type: "blob" });
// 创建下载链接
const downloadLink = document.createElement("a");
downloadLink.href = URL.createObjectURL(content);
downloadLink.download = `批量附件下载(${this.checkedCities.length}).zip`;
// 点击下载链接自动下载
downloadLink.click();
this.batchLoading = false;
} catch (error) {
console.error(error);
}
},

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值