前端将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)
}
相关推荐
S***H2838 分钟前
Vue语音识别案例
前端·vue.js·语音识别
q***25126 分钟前
java进阶1——JVM
java·开发语言·jvm
while(1){yan}27 分钟前
线程的状态
java·开发语言·jvm
豐儀麟阁贵30 分钟前
8.3 Java常见的异常类
java·开发语言
lzh2004091935 分钟前
【C++STL】List详解
开发语言·c++
q***448138 分钟前
Java进阶10 IO流
java·开发语言
济宁雪人44 分钟前
Java安全基础——文件系统安全
java·开发语言·安全
Charles_go1 小时前
C#中级46、什么是模拟
开发语言·oracle·c#
啦啦9118861 小时前
【版本更新】Edge 浏览器 v142.0.3595.94 绿色增强版+官方安装包
前端·edge
20岁30年经验的码农1 小时前
Java RabbitMQ 实战指南
java·开发语言·python