用JSZip,FileSaver 有现成cdn的http图片或者文件地址,弄成压缩包导出,解决如果文件名字都是一样的只导出一个图片或文件的方法

  1. 第一步先处理重名的数据 ,
    解决方法 :将相同名字的图片或文件后面加后缀数字作为区分

    let arr = [{name:'图片一',url:'http://cdn'}, {name:'图片一',url:'http://cdn'}, {name:'图片二',url:'http://cdn'}];

    // 创建一个对象来跟踪已经遇到的名称和它们的计数
    let nameCounts = {};
    // 遍历数组,并更新对象
    arr.forEach((obj, index) => {
    // 如果当前对象的name在nameCounts中存在,说明是重名
    if (nameCounts[obj.name]) {
    // 增加计数,并更新对象的name属性,添加序号
    obj.name = ${obj.name}(${nameCounts[obj.name]});
    // 更新nameCounts中对应name的计数
    nameCounts[obj.name]++;
    } else {
    // 如果name不存在于nameCounts中,则初始化为1(但实际上不会立即用到这个1)
    nameCounts[obj.name] = 1;
    }
    // 注意:对于不重名的name,我们不会更改它们的name属性,也不会增加nameCounts中的计数
    });
    console.log(arr);
    // [ { name: '图片一(1)' }, { name: '图片一(2)' }, { name: '图片二' } ]

  2. 引入

    import JSZip from "jszip";
    import FileSaver from "file-saver";

  3. 点击导出按钮 ,压缩包导出

    async down(){
    let zip = new JSZip();
    for (let i = 0; i < this.arr.length; i++) {
    let file = arr[i].url.split(".");
    let fileType = file[file.length - 1];
    const fileName = arr[i].name
    // 文件类型 DOC XLS 等等都可以加进来
    if (fileType.toLocaleUpperCase() === "PDF") {
    await this.getFile(this.arr[i].url).then((res) => zip.file(fileName, res, { binary: true }))
    } else { // 图片
    await this.getBase64Img(this.arr[i].url).then((res) => zip.file(fileName, res, { base64: true }));
    }
    zip.generateAsync({ type: "blob" }).then((content) => {
    let fileName = "批量导出.zip";
    FileSaver.saveAs(content, fileName);
    });
    }
    },
    getFile(url) {
    return new Promise((resolve, reject) => {
    this.$http({ method: "get" , url , responseType: "arraybuffer" }).then((data) => resolve(data.data)).catch((error) => reject("PDF加载失败:" + error));
    });
    },
    getBase64Img(url) {
    return new Promise((resolve, reject) => {
    var base64 = "";
    var img = new Image();
    img.setAttribute("crossOrigin", "Anonymous");
    img.onload = () => {
    base64 = this.canBase64(img);
    resolve(base64.split(",")[1]);
    };
    img.onerror = () => reject("加载失败"); // 这里可能会有跨域失败的问题,解决方案同上,url + 随机数
    img.src = url + "?t=" + new Date().getTime();
    });
    },
    canBase64(img) {
    var canvas = document.createElement("canvas");
    canvas.width = img.width;
    canvas.height = img.height;
    var ctx = canvas.getContext("2d");
    ctx.drawImage(img, 0, 0, img.width, img.height);
    var dataURL = canvas.toDataURL("image/png");
    return dataURL;
    }

相关推荐
qq. 28040339844 小时前
CSS层叠顺序
前端·css
喝拿铁写前端4 小时前
SmartField AI:让每个字段都找到归属!
前端·算法
猫猫不是喵喵.4 小时前
vue 路由
前端·javascript·vue.js
烛阴4 小时前
JavaScript Import/Export:告别混乱,拥抱模块化!
前端·javascript
bin91535 小时前
DeepSeek 助力 Vue3 开发:打造丝滑的表格(Table)之添加行拖拽排序功能示例12,TableView16_12 拖拽动画示例
前端·javascript·vue.js·ecmascript·deepseek
GISer_Jing5 小时前
[Html]overflow: auto 失效原因,flex 1却未设置min-height &overflow的几个属性以及应用场景
前端·html
程序员黄同学5 小时前
解释 Webpack 中的模块打包机制,如何配置 Webpack 进行项目构建?
前端·webpack·node.js
拉不动的猪5 小时前
vue自定义“权限控制”指令
前端·javascript·vue.js
再学一点就睡5 小时前
浏览器页面渲染机制深度解析:从构建 DOM 到 transform 高效渲染的底层逻辑
前端·css
拉不动的猪6 小时前
刷刷题48 (setState常规问答)
前端·react.js·面试