当前位置: 首页 > article >正文

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

吃西瓜

现成的粒子

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

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

  • 常见的: ‘Blob、ArrayBuffer、File、FileReader 和 FormData’
  • 在浏览器中长这样:
    在这里插入图片描述



blobType 指的是,服务端返回的 Content-Typemine-type
常用的excel类型一般有2种:application/vnd.ms-excelapplication/vnd.openxmlformats-officedocument.spreadsheetml.sheet

如:
在这里插入图片描述


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' 配置项
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文本类型

http://www.kler.cn/a/313691.html

相关文章:

  • Rust:指针 `*T` 和引用 `T`的区别
  • flutter 常用UI组件
  • 深度学习项目--基于LSTM的火灾预测研究(pytorch实现)
  • LLM - 大模型 ScallingLaws 的 CLM 和 MLM 中不同系数(PLM) 教程(2)
  • 异步 HTTP 请求
  • 2025.1.16——六、BabySQL 双写绕过|联合注入
  • 2024“华为杯”中国研究生数学建模竞赛(E题)深度剖析|数学建模完整过程+详细思路+代码全解析
  • 【Linux取经之路】软件包管理器yum编辑器vim及其配置
  • 进程间关系与进程守护
  • 浅析OceanBase数据库的向量化执行引擎
  • CSS中如何实现鼠标悬停效果?
  • 数据结构:(牛客OR36)链表的回文结构
  • (笔记自用)LeetCode:快乐数
  • mysql时间戳格式化yyyy-mm-dd
  • kubeadm方式安装k8s+基础命令的使用
  • 二层、三层网络基本原理
  • 缓存技巧 · Spring Cache Caffeine 高性能缓存库
  • Github 2024-09-20 Java开源项目日报Top10
  • 【快手】前端校招一面
  • 深入理解Python中的时间表示:Unix时间点、毫秒和微秒,以及time模块
  • 9.7floodFill图像分割
  • 98-策略模式的理解
  • 蓝桥杯—STM32G431RBT6(ADC数模转换,从原理到应用)
  • C++第十一节课 new和delete
  • [Python可视化]数据可视化在医疗领域应用:提高诊断准确性和治疗效果
  • AI视觉算法盒是什么?如何智能化升级网络摄像机,守护全方位安全