js 将二进制文件流,下载为excel文件

吃西瓜

现成的粒子

二进制流,是一种计算机文件格式,它的数据以二进制形式存储,与文本文件不同,

二进制文件可以包含任意类型的数据,例如:图像、音频、视频、可执行文件、压缩文件等,而文本文件则仅仅包含 ASCII 码或其他编码的字符数据。

  • 常见的: 'Blob、ArrayBuffer、File、FileReader 和 FormData'
  • 在浏览器中长这样:



blobType 指的是,服务端返回的 Content-Typemine-type

常用的excel类型一般有2种:application/vnd.ms-excelapplication/vnd.openxmlformats-officedocument.spreadsheetml.sheet

如:

javascript 复制代码
export const filmOrderExcelOut = (parameter: Record<any, any>) => {
	return request({
		method: 'post',
		url: Api.filmOrderExcelOut,
		data: parameter,
		responseType: 'blob'   `【一定得加这个】`
	})
}

--------------------------------------------------------------------

// 导出表格
const exportExcel = async () => {
	try {
		let { data } = await orderApi.filmOrderExcelOut(searchParams.value)
		
		let blob = new Blob([data], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' })
		
		let file = new File([blob], '订单.xlsx', {
			lastModified: new Date() as any,
			type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
		})
		// console.log('file=', file)
		
		const a = document.createElement('a')
		a.style.display = 'none'
		document.body.appendChild(a)
		const url = URL.createObjectURL(file)
		a.href = url
		a.download = file.name
		a.click()
		// 清理
		document.body.removeChild(a)
		URL.revokeObjectURL(url)
	} catch (error) {
		message.error('网络请求发送失败~')
	}
}

出错的地方

  • 问题:成功将文件流转换成了excel文件,并下载了,但是下载后的文件打不了!!!
  • 原因:就是因为请求接口时,少了这个 responseType: 'blob' 配置项
javascript 复制代码
export const filmOrderExcelOut = (parameter: Record<any, any>) => {
	return request({
		method: 'post',
		url: Api.filmOrderExcelOut,
		data: parameter,
		responseType: 'blob'   `【一定得加这个】`
	})
}

`responseType`:表示,服务器响应的数据类型,可以是 'arraybuffer','blob','document','json','text','stream'等
  • arraybuffer:设置响应类型为二进制对象【返回的是一个包含二进制数据的 JavaScript ArrayBuffer 类型化数组】
  • blob:设置响应类型为二进制对象【返回的是一个包含二进制数据的 Blob 对象】
  • document: 设置响应类型为html document 或 xml document,具体根据接收到的数据的 MIME 类型而定
  • json: 设置响应类型为json类型,日常开发中常用
  • text:设置响应类型为text文本类型
相关推荐
EndingCoder9 分钟前
Electron 跨平台兼容性:处理 OS 差异
前端·javascript·electron·前端框架·node.js·chrome devtools
zhong liu bin25 分钟前
Vue框架技术详解——项目驱动概念理解【前端】【Vue】
前端·javascript·vue.js·vscode·vue
前端 贾公子43 分钟前
ElementUI 中 validateField 对部分表单字段数组进行校验时多次回调问题
前端·javascript·elementui
棒棒的唐43 分钟前
vue2 elementUI 登录页面实现回车提交登录的方法
前端·javascript·elementui
知识分享小能手1 小时前
React学习教程,从入门到精通,React 使用属性(Props)创建组件语法知识点与案例详解(15)
前端·javascript·vue.js·学习·react.js·前端框架·vue
摸鱼的春哥2 小时前
前端程序员最讨厌的10件事
前端·javascript·后端
牧羊狼的狼6 小时前
React 中的 HOC 和 Hooks
前端·javascript·react.js·hooks·高阶组件·hoc
知识分享小能手7 小时前
React学习教程,从入门到精通, React 属性(Props)语法知识点与案例详解(14)
前端·javascript·vue.js·学习·react.js·vue·react
luckys.one7 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
mCell8 小时前
JavaScript 的多线程能力:Worker
前端·javascript·浏览器