前端将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)
}
相关推荐
froginwe113 分钟前
Vue.js 监听属性
开发语言
c++逐梦人4 分钟前
五种IO模型与⾮阻塞IO
开发语言·网络
翎沣6 分钟前
C++面向对象三大特性
开发语言·c++
@PHARAOH6 分钟前
HOW - 构建一个轻量前后端一体服务
前端·微服务·服务端
驭渊的小故事6 分钟前
java中的进程的详细解析
java·开发语言
烟雨江南aabb12 分钟前
Python第六弹:python爬虫篇:什么是爬虫
开发语言·爬虫·python
沐知全栈开发13 分钟前
Servlet 文件上传详解
开发语言
无限进步_17 分钟前
【C++】C++11的类功能增强与STL变化
java·前端·数据结构·c++·后端·算法
一只小小Java18 分钟前
Echarts单表多图实现
前端·javascript·echarts
跟着珅聪学java19 分钟前
Element UI 的 Tabs 标签页开发教程
javascript·vue.js·elementui