前端实现多个图片打包下载

复制代码
npm install jszip file-saver --save
复制代码
import JSZip from "jszip";
import FileSaver from "file-saver";

const list = ref([
	"https://jiaming-test.oss-cn-huhehaote.aliyuncs.com/1993221725990686720/material/e43c4d50-02dc-4614-9132-64f15511a17e.png",
	"https://jiaming-test.oss-cn-huhehaote.aliyuncs.com/1993221725990686720/material/7bea4925-6e8d-4d79-98b0-0196d2db2bcc.png",
	"https://jiaming-test.oss-cn-huhehaote.aliyuncs.com/1993221725990686720/material/ed294f8d-088d-4648-bbe9-68ab98039173.png",
	"https://jiaming-test.oss-cn-huhehaote.aliyuncs.com/1993221725990686720/material/a531dedb-9359-49bf-bb0e-86f85bfbdcf6.png",
	"https://jiaming-test.oss-cn-huhehaote.aliyuncs.com/1993221725990686720/material/71077921-7647-469b-8f42-8fa804c2cf00.png"
]);
// 单个图片转Blob
const getImageBlob = async (imageUrl) => {
	try {
		// 处理阿里云OSS图片跨域(添加cors模式)
		const response = await fetch(imageUrl, {
			mode: "cors",
			cache: "no-cache"
		});
		if (!response.ok) throw new Error(`图片加载失败: ${response.status}`);
		return await response.blob();
	} catch (error) {
		console.error(`处理图片失败: ${imageUrl}`, error);
		return null;
	}
};

// 批量打包下载主函数
const downloadImagesAsZip = async () => {
	const zip = new JSZip();
	try {
		// 遍历图片列表,添加到压缩包
		const promises = list.value.map(async (url, index) => {
			const blob = await getImageBlob(url);
			if (blob) {
				// 提取图片名称(或自定义命名,如 图片1.png、图片2.png)
				const fileName = url.split("/").pop() || `图片${index + 1}.png`;
				zip.file(fileName, blob); // 添加到压缩包
			}
		});
		// 等待所有图片处理完成
		await Promise.all(promises);

		// 生成压缩包(开启压缩减小体积)
		const zipBlob = await zip.generateAsync({
			type: "blob",
			compression: "DEFLATE",
			compressionOptions: { level: 6 }
		});

		// 下载压缩包(自定义文件名)
		FileSaver.saveAs(zipBlob, "阿里云OSS图片包.zip");
	} catch (error) {
		console.error("打包下载失败", error);
	}
};

效果

相关推荐
IT_陈寒14 分钟前
Vite动态导入把我坑惨了,原来要这样用才对
前端·人工智能·后端
DFT计算杂谈18 分钟前
KPROJ编译教程
java·前端·python·算法·conda
觅_20 分钟前
前端学习后端的时候 选择一个技术
前端·学习
独泪了无痕23 分钟前
CryptoJS:数据安全的JavaScript加密利器
前端·vue.js·node.js
发现一只大呆瓜1 小时前
一文搞懂 Vite 处理CommonJS包、按需编译逻辑及 Rollup 插件兼容规则
前端
Edwardwu1 小时前
写了个y-mxgraph:给 draw.io 接上了 Yjs,顺便解决了部署在 iframe 里的一堆问题
前端·typescript
其实防守也摸鱼1 小时前
软件安全与漏洞--软件安全编码
java·前端·网络·安全·网络安全·web·工具
发现一只大呆瓜2 小时前
Vite 开发预构建机制详解,搞懂 esbuild 与 Rollup 分工差异
前端·面试·vite
九九落3 小时前
前端获取经纬度完全指南:从Geolocation API到地图集成
前端·获取经纬度
来恩10033 小时前
jQuery选择器
前端·javascript·jquery