(1)适用场景
下载文件的接口一般会返回blob或者ArrayBuffer的格式,但是当不符合下载条件时,后端会返回json格式提示为何不能下载,但是responseType只能设置一种格式,这时只能设置responseType="blob"或者responseType="ArrayBuffer",当返回json时,我们把blob或者ArrayBuffer格式转为json即可。
image.png
(2)解决办法
报错原因:接口返回json,但是因为前端设置了responseType="blob",所以response是blob类型,这时获取responseText也会报错
解决办法:将blob类型的二进制流转换成JSON格式就行了
// 将blob转为json
let reader = new FileReader()
reader.readAsText(res)
setTimeout(()=>{
let resData = JSON.parse(reader.result)
},500)
// 如果转换完中文出现乱码,可以设置一下代码
reader.readAsText(xhr.response, "utf-8")
这样,在返回blob时正常下载,在返回json时,转换一下,即可正常获取返回的json提示信息。
(3)如果需要显示二进制流文件
var blob = new Blob([response.data]);
var downloadElement = document.createElement("a");
var href = window.URL.createObjectURL(blob); //创建下载的链接
downloadElement.href = href;
downloadElement.download = "下载的文件"+ ".xlsx"; //下载后文件名
document.body.appendChild(downloadElement);
downloadElement.click(); //点击下载
document.body.removeChild(downloadElement); //下载完成移除元素
window.URL.revokeObjectURL(href); //释放掉blob对象