请求为blob,但是返回json格式,如何处理

在 Vue 3 中,如果你收到一个本应该是 blob 但实际上是 json 格式的响应,并且你错误地尝试使用 FileReader 来读取它,这实际上是不必要的,因为 json 数据已经是文本格式,可以直接被 JavaScript 处理。

但是,如果你确实收到的是二进制数据(可能是以 arraybufferblob 形式),并且这些数据实际上包含了 json 格式的文本,那么你需要使用 FileReader 来读取这些数据,并将其转换为文本,然后再解析为 JSON 对象。

下面是一个处理这种情况的示例:

javascript 复制代码
axios({  
  method: 'get',  
  url: '你的API地址',  
  responseType: 'blob' // 假设后端错误地返回了blob,但内容实际上是json格式的文本  
})  
.then(response => {  
  // 创建一个FileReader对象来读取blob数据  
  const reader = new FileReader();  
  reader.readAsText(response.data, 'utf-8'); // 读取blob数据为文本  
  reader.onload = function (e) {  
    try {  
      // 将读取到的文本解析为JSON对象  
      const jsonData = JSON.parse(e.target.result);  
      // 在这里使用解析后的JSON数据  
      console.log('jsonData:', jsonData);  
      // 根据返回的json数据做不同的操作  
      // ...  
    } catch (error) {  
      // 处理解析JSON时可能出现的错误  
      console.error('Error parsing JSON:', error);  
    }  
  };  
  reader.onerror = function (error) {  
    // 处理FileReader可能出现的错误  
    console.error('FileReader error:', error);  
  };  
})  
.catch(error => {  
  // 处理axios请求时可能出现的错误  
  console.error('Error fetching data:', error);  
});

在JavaScript中,由于浏览器环境的限制,文件读取操作通常是异步的,包括使用FileReader API 读取二进制文件内容。这是因为读取文件涉及到磁盘I/O操作,这可能需要一些时间,而JavaScript是单线程的,如果进行同步读取,可能会阻塞整个页面,导致用户体验下降。

因此,尽管有时我们可能希望同步读取文件内容以便更直接地处理数据,但在Web浏览器中通常不支持同步文件读取。FileReader API 没有提供同步读取的方法,所有的读取操作都是通过事件驱动的异步方式完成的。

相关推荐
张3蜂11 分钟前
Python 四大 Web 框架对比解析:FastAPI、Django、Flask 与 Tornado
前端·python·fastapi
南风知我意95711 分钟前
【前端面试5】手写Function原型方法
前端·面试·职场和发展
qq_124987075312 分钟前
基于Java Web的城市花园小区维修管理系统的设计与实现(源码+论文+部署+安装)
java·开发语言·前端·spring boot·spring·毕业设计·计算机毕业设计
VX:Fegn089526 分钟前
计算机毕业设计|基于springboot + vue云租车平台系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
小安驾到37 分钟前
【前端的坑】vxe-grid表格tooltip提示框不显示bug
前端·vue.js
去码头整点薯条981 小时前
python第五次作业
linux·前端·python
计算机学姐1 小时前
基于SpringBoot的校园社团管理系统
java·vue.js·spring boot·后端·spring·信息可视化·推荐算法
数研小生1 小时前
1688商品列表API:高效触达批发电商海量商品数据的技术方案
大数据·python·算法·信息可视化·json
沐墨染1 小时前
Vue实战:自动化研判报告组件的设计与实现
前端·javascript·信息可视化·数据分析·自动化·vue
局外人LZ1 小时前
Uniapp脚手架项目搭建,uniapp+vue3+uView pro+vite+pinia+sass
前端·uni-app·sass