前端将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)
}
相关推荐
Elastic 中国社区官方博客9 小时前
从向量到关键词:在 LangChain 中的 Elasticsearch 混合搜索
大数据·开发语言·数据库·elasticsearch·搜索引擎·ai·langchain
学编程的闹钟9 小时前
C语言GetLastError函数
c语言·开发语言·学习
梵刹古音9 小时前
【C++】多态
开发语言·c++
山岚的运维笔记9 小时前
SQL Server笔记 -- 第34章:cross apply
服务器·前端·数据库·笔记·sql·microsoft·sqlserver
hello 早上好9 小时前
07_JVM 双亲委派机制
开发语言·jvm
前端程序猿i9 小时前
第 8 篇:Markdown 渲染引擎 —— 从流式解析到安全输出
开发语言·前端·javascript·vue.js·安全
coding随想9 小时前
告别构建焦虑!用 Shoelace 打造零配置的现代 Web 应用
前端
kronos.荒9 小时前
滑动窗口:寻找字符串中的字母异位词
开发语言·python
css趣多多10 小时前
resize.js
前端·javascript·vue.js
_codemonster10 小时前
java web修改了文件和新建了文件需要注意的问题
java·开发语言·前端