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

vue 打包下载多层zip文件

 

 

npm install jszip
npm install file-saver
import JSZip from "jszip";
import FileSaver from "file-saver";
import {Message} from "view-design";/*** 下载文件 传数组* fileList* [*   {*     type:'file',*     name:'17034953113790548.png',*     url:'https://zwdev.oss-cn-beijing.aliyuncs.com/company_1/default/17034953113790548.png',*   },*   {*     type:'folder',*     name:'图片',*     children:[*       {*         type:'file',*         name:'17034953113790548.png',*         url:'https://zwdev.oss-cn-beijing.aliyuncs.com/company_1/default/17034953113790548.png',*       },*     ]*   }* ]* @param {*} fileList* @param fileName //zip文件名称 默认时间戳*/export function downLoadZip(fileList, fileName = new Date().getTime()) {const zip = new JSZip()const promises = []fileList.forEach((item, index) => {if (item.type === 'folder') {let promiseFolder = zip.folder(item.name)//文件夹名if (item.children && item.children.length > 0) {item.children.forEach((file, ii) => {let promise = getFile(file.url).then((data) => {promiseFolder.file(file.name, data, {binary: true})//文件名、文件流、是否为二进制})promises.push(promise)})}} else if (item.type === 'file') {let promise = getFile(item.url).then((data) => {zip.file(item.name, data, {binary: true})//文件名、文件流、是否为二进制})promises.push(promise)}})Promise.all(promises).then(() => {zip.generateAsync({type: 'blob'}).then((content) => {//利用file-saver保存文件  自定义文件名FileSaver.saveAs(content, fileName)})}).catch((err) => {Message.error({content: '文件压缩失败' + err})})}function getFile(url) {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();});
}

http://www.lryc.cn/news/291794.html

相关文章:

  • Flink实战五_状态机制
  • SQL中having与where的区别 简单明了
  • Transformer 自然语言处理(二)
  • 软件测试之软件缺陷管理
  • 分布式锁(Distributed Lock)介绍(基于数据库(mysql);基于缓存(redis);基于ZooKeeper等分布式协调服务)
  • 10 ISIS 基础 报文 状态
  • Python第三方扩展库Matplotlib
  • 单例模式有几种写法?请谈谈你的理解?
  • 帕鲁幻兽 一键开服 简单到爆 教你10秒实现 帕鲁幻兽私服联机服务器搭建
  • 自动化报告pptx-python|如何将pandas的表格写入PPTX(二)
  • Ruby详解及安装流程
  • 免费的ChatGPT网站 ( 7个 )
  • python异步编程(1)——理论篇
  • PyTorch复现网络模型VGG
  • Springboot集成Javamelody
  • 如何将 h5 页面快速转换成微信小程序
  • 在Vue的模块开发中使用GPT的体验及总结
  • Java常见算法题解析面试题(中)
  • 提升网站性能的秘诀:为什么Nginx是高效服务器的代名词?
  • [Python图像处理] 使用OpenCV创建深度图
  • vue+element 换肤功能
  • python魔法函数[全面]
  • python实现贪吃蛇小游戏(附源码)
  • 爬虫学习笔记-Cookie登录古诗文网
  • Linux网络状态查看与防火墙管理
  • VxTerm:C++ MFC,在工具栏中增加Edit/ComboBox等组件,打造一个地址栏/搜索栏功能
  • 【Android】屏幕锁
  • springCloud gateway 防止XSS漏洞
  • 美赛摘要写作重点
  • RUST笔记: 动态链接库的创建和使用