vue前端拿到后端pdf与zip等重新打包为一个新的zip包

目录

vue前端拿到后端pdf与zip等重新打包为一个新的zip包

code.vue

js 复制代码
      const urlList = [
        {
          fileUrl:'https://XX.zip',
          fileName:'我是文件.zip'
        },
        {
          fileUrl:'https://XXX.pdf',
          fileName:'我是pdf.pdf'
        }
      ]
      this.downloadZip(urlList)

    downloadZip(urlList){
      console.log('downloadZip',urlList);
      // 创建一个zip
      const zip = new JSZip();
      // 获取文件 放入zip包中
      const fetchAndAddToZip = async (fileUrl, fileName) => {
        const response = await fetch(fileUrl);
        const fileBlob = await response.blob();
        zip.file(fileName, fileBlob, { binary: true });
      };
      // 生成下载zip包
      const generateAndDownloadZip = async () => {
        // 遍历把文件丢到zip包中
        for (const url of urlList) {
          await fetchAndAddToZip(url.fileUrl, url.fileName);
        }
        // 生成一个zip包
        const content = await zip.generateAsync({ type: 'blob' });
        // 保存到本地
        FileSaver.saveAs(content, 'files.zip');
      };

      generateAndDownloadZip();
    }
相关推荐
疯狂的沙粒7 分钟前
Vue 前端大屏做多端屏幕适配时,如何让其自动适配多种不同尺寸的屏幕?
前端·javascript·vue.js
范小多10 分钟前
24小时学会Python Visual code +Python Playwright通过谷歌浏览器取控件元素(连载、十一)
服务器·前端·python
ooolmf11 分钟前
matlab2024读取温度01
java·前端·javascript
打工人小夏12 分钟前
前端vue3项目使用nprogress动画组件,实现页面加载动画
前端
一颗宁檬不酸14 分钟前
前端农业商城中产品产地溯源功能的实现
前端
李少兄21 分钟前
深入理解前端中的透视(Perspective)
前端·css
江公望31 分钟前
HTML5 History 模式 5分钟讲清楚
前端·html·html5
云和数据.ChenGuang38 分钟前
Zabbix Web 界面安装时**无法自动创建配置文件 `zabbix.conf.php`** 的问题
前端·zabbix·运维技术·数据库运维工程师·运维教程
码界奇点40 分钟前
Java Web学习 第15篇jQuery万字长文详解从入门到实战解锁前端交互新境界
java·前端·学习·jquery
前端老曹1 小时前
vue3 三级路由无法缓存的终极解决方案
前端·javascript·vue.js·vue