当前位置: 首页 > news >正文

vue3 多文件下载zip压缩包

vue3多文件下载zip文件包

效果图

在这里插入图片描述

代码块

在这里插入代码片
<template><div><el-button type="primary" @click="downLoadClick">下载文件zip</el-button></div>
</template><script setup lang="ts">
import JSZip from "jszip";   // "jszip": "^3.10.1",const fileUrls = ["https://xxxx.aliyuncs.com/erp-test-upload/note/2024/07/14/1/18123873099490877141/消息通知-未读-20240711185838.xlsx","https://xxxx.aliyuncs.com/erp-test-upload/note/2024/07/14/1/1812387309907144404/th.jpg"
];
const zip = new JSZip();// 下载文件函数
const downLoadClick = async () => {try {await fileSteam(fileUrls); // 等待所有文件处理完毕const blob = await zip.generateAsync({type: 'blob'});const url = window.URL.createObjectURL(blob);const a = document.createElement('a');a.href = url;a.download = 'files.zip'; // 自定义下载的zip文件名称a.click();window.URL.revokeObjectURL(url);} catch (error) {console.error('生成压缩包或下载过程中发生错误:', error);}
};// 文件转文件流且将文件流转成JSZip认可的格式
const fileSteam = async (urls: string[]) => {const promises = urls.map(async (url) => {try {const response = await fetch(url);const blob = await response.blob();const arrayBuffer = await blob.arrayBuffer();const fileName = url.split('/').pop();  // 从 URL 中提取文件名zip.file(fileName || 'file', new Uint8Array(arrayBuffer));} catch (error) {console.error(`Fetch file from ${url} failed:`, error);}});// 等待所有文件都处理完毕await Promise.all(promises);
};</script>

http://www.mrgr.cn/news/7149.html

相关文章:

  • 基于AT32F421的开源电调项目测试
  • 获取当前时间戳
  • Nginx配置负载均衡
  • 如何使用 Java 中的 API 更改 PDF 纸张大小
  • 『基础』线性代数-1行列式
  • 【吊打面试官系列-Memcached面试题】memcached 能接受的 key 的最大长度是多少?
  • 亚信科技转型持久战:扎根行业大模型,深耕行业数字化
  • 户用光伏项目如何操作?
  • 鸿蒙 点击获取电话号拨打电话 @ohos.telephony.call (拨打电话)
  • 【机器翻译方向】数据集合集!
  • 在JavaScript中,如何实现异步编程?
  • Linux驱动入门实验班——DAC模块驱动(附百问网视频链接)
  • [ACTF新生赛2020]music附赠支持多国语言Fuzz语音转录文本翻译软件下载安装使用简介
  • 【jvm】程序计数器的特征
  • 前端css溢出属性overflow
  • [sqlserver][sql]sqlserver跨主机访问 跨数据库访问 数据库链接
  • windows安全软件之火绒杀毒的密码忘记后处理
  • 什么是CUDA
  • 学习记录:js算法(十二):柱状图中最大的矩形
  • 【联想电脑】:使用拓展坞后转接HDMI,无法识别显示屏