前端将blob转换为可下载的url及下载

一.转换

javascript 复制代码
//将blob转换为url
const changeBlobToUrl = blobData => {
	return new Promise(resolve => {
		//创建Blob对象
		const blob = new Blob([blobData])

		// 创建FileReader对象
		const reader = new FileReader()

		reader.onload = function (e) {
			resolve(e.target.result)
		}

		// 使用FileReader读取Blob数据
		reader.readAsDataURL(blob)
	})
}

二.下载

javascript 复制代码
//前端下载blob的url类型文件
const downloadFileByBlobUrl = (url: string, name: string) => {
	aDownload(url, name)
	URL.revokeObjectURL(url)
}


const aDownload = (url, name) => {
	// 创建<a>元素
	const link = document.createElement("a")
	// 设置<a>元素的属性
	link.href = url
	link.download = name
	// 将<a>元素添加到文档中
	document.body.appendChild(link)
	// 触发点击事件
	link.click()
	// 移除<a>元素
	document.body.removeChild(link)
}
相关推荐
NEXT062 分钟前
React 性能优化:图片懒加载
前端·react.js·面试
PineappleCoder13 分钟前
别让字体拖了后腿:FOIT/FOUT 深度解析与字体加载优化全攻略
前端·性能优化
CeshirenTester33 分钟前
9B 上端侧:多模态实时对话,难点其实在“流”
开发语言·人工智能·python·prompt·测试用例
发现你走远了35 分钟前
Windows 下手动安装java JDK 21 并配置环境变量(详细记录)
java·开发语言·windows
NEXT0641 分钟前
后端跑路了怎么办?前端工程师用 Mock.js 自救实录
前端·后端·程序员
游乐码1 小时前
c#类和对象
开发语言·c#
黎雁·泠崖1 小时前
Java常用类核心详解(一):Math 类超细讲解
java·开发语言
懒惰成性的2 小时前
12.Java的异常
java·开发语言
-To be number.wan2 小时前
Python数据分析:时间序列数据分析
开发语言·python·数据分析
装不满的克莱因瓶2 小时前
Java7新特性:try-with-resources写法
java·前端·javascript·jdk·新特性·jdk7