-
第一步先处理重名的数据 ,
解决方法 :将相同名字的图片或文件后面加后缀数字作为区分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: '图片二' } ] -
引入
import JSZip from "jszip";
import FileSaver from "file-saver"; -
点击导出按钮 ,压缩包导出
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;
}
用JSZip,FileSaver 有现成cdn的http图片或者文件地址,弄成压缩包导出,解决如果文件名字都是一样的只导出一个图片或文件的方法
烂笔头12024-07-02 1:35
相关推荐
薛定猫AI11 小时前
【深度解析】Gemma Chat 本地 AI 编程 Agent:Electron + MLX + 开源模型的离线 Vibe Coding 实战kyriewen11 小时前
Webpack vs Vite:一个是“老黄牛”,一个是“猎豹”,你选谁?打小就很皮...11 小时前
html2canvas + jsPDF 生成 PDF 的踩坑与解决方案总结全栈前端老曹11 小时前
【前端地图】多地图平台适配方案——高德、百度、腾讯、Google Maps SDK 差异对比、封装统一地图接口笑虾11 小时前
Win10 修改注册表 让鼠标悬停PNG上时 tip 始终显示分辨率雾岛听风69112 小时前
JavaScript基础语法速查手册遇见~未来12 小时前
第三篇_现代布局_从弹性到网格前端那点事12 小时前
Vue前端SEO优化全攻略(实操落地版,新手也能上手)Dxy123931021612 小时前
HTML 如何使用 SVG 画曲线用户23678298016812 小时前
从零实现 GIF 制作工具:LZW 压缩与 Median Cut 色彩量化