当设置response为blob时,但是返回错误提示的处理方式

该代码段展示了一个使用Axios发送请求后,根据返回数据类型是JSON还是Blob进行不同处理的示例。如果响应数据是JSON,则解析并检查状态;如果是Blob,它将创建一个文件下载链接供用户保存。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

根据判断返回值是json还是blob对应处理;

axios.request('url').then((res)=>{
	const promise=new Promise((resolve,reject)=>{
	const fileReader = new FileReader();
	const blob = new Blob([res.data]);
	fileReader.onload = function(){
		try{
			const jsoninfo = JSON.parse(this.result);
			jsoninfo.status === 0?reject(jsoninfo):resolve(jsoninfo);
		}.catch(err){resolve(err) }
	};
		fileReader.readAsText(blob);
});
promise.then(data=>{
	const blob = new Blob([res.data]);
	const objurl = window.URL.createObjectURL(blob);
	const fileName = res.header.filename,'UTF-8';
	const link = document.createElement('a');
	link.setAttribute('href',objurl);
	link.setAttribute('download',fileName);
	link.click();
}).catch(()=>{})
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值