接口返回blob和json两种格式时,前端怎么处理

当前端设置responseType为'blob'或'ArrayBuffer'时,遇到后端返回json格式的数据,可以通过FileReader读取并转换为json。在加载结束事件中,使用JSON.parse解析reader.result得到json内容。若遇到中文乱码,可指定utf-8编码读取。此方法确保了在处理下载文件和接收json提示信息时的兼容性。

为什么会这样?

下载文件的接口一般会返回blob或者ArrayBuffer的格式,但是当不符合下载条件时,后端会返回json格式提示为何不能下载,但是responseType只能设置一种格式,这时只能设置responseType="blob"或者responseType="ArrayBuffer",当返回json时,我们把blob或者ArrayBuffer格式转为json即可。

以下是接口返回json,但是因为前端设置了responseType="blob",所以response是blob类型,这时获取responseText也会报错。

 responseText: [Exception: DOMException: Failed to read the 'responseText' property from 'XMLHttpRequest': 

如何讲blob类型的二进制流转换成JSON格式

// 将blob转为json

let reader = new FileReader()
reader.addEventListener("loadend", () => {
    // 将会打印json格式
    console.log(JSON.parse(reader.result))
})
// 如果转换完中文出现乱码,可以设置一下代码
reader.readAsText(xhr.response, "utf-8")

这样,在返回blob时正常下载,在返回json时,转换一下,即可正常获取返回的json提示信息。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值