前端将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)
}
相关推荐
阿猿收手吧!7 分钟前
【C++】高并发内存池架构与设计解析
开发语言·c++·架构
唠玖馆16 分钟前
c++ 类和对象(全)
java·开发语言·c++
李剑一18 分钟前
别再瞎写电子围栏了!这2种动态效果,科技感直接拉满,源码直接抄走!
前端·vue.js·cesium
echome88820 分钟前
Python 异步编程实战:async/await 从入门到精通
开发语言·python·php
木易士心37 分钟前
从 MVP 到千万级并发:AI 在前后端开发中的差异化落地指南
前端·后端
葡萄城技术团队39 分钟前
字体与打印:前端开发最常见的三个“为什么”
前端
王夏奇41 分钟前
python中的深浅拷贝和上下文管理器
java·服务器·前端
小杍随笔42 分钟前
【Rust 语言编程知识与应用:自定义数据类型详解】
开发语言·后端·rust
siger1 小时前
徒手开荒-我用纯Nodejs+pnpm+monorepo改造了一个多vue2的iframe"微前端"项目
前端·node.js·前端工程化
lichenyang4531 小时前
海克斯大乱斗攻略网站 —— 从零开发到云服务器部署全记录
前端