Responsetype blob会把接口接收的二进制文件转换成blob格式

在 Axios(从代码里 request 推测是基于 Axios 封装的请求方法 )中,responseType: 'blob' 的作用是告知请求方,期望服务端返回的数据以 Blob 格式进行处理,让浏览器把接口返回的二进制数据(比如文件流)封装成 Blob 对象,方便前端做文件下载、预览等操作,核心逻辑是浏览器根据你设置的 responseType ,按照对应的规则解析服务端返回的响应体 ,下面展开说:

  1. 原理层面

• 服务端返回的本质是 HTTP 响应,包含响应头、响应体(二进制内容,像文件的字节流 )。

• 当你在 Axios 里设置 responseType: 'blob' ,浏览器在接收响应后,会依据这个配置,把响应体的二进制数据包装成 Blob 对象(Blob 是浏览器 Web API 里的类型,用于表示"二进制大对象" ),这样前端拿到的 response.data 就是 Blob 实例,能直接用于创建 URL 做下载(URL.createObjectURL(blob) )、传给文件处理 API 等。

  1. 对比其他类型

• 如果不设置 responseType ,默认是 json ,浏览器会尝试把响应体按 JSON 去解析,要是服务端返回的是二进制文件流,解析就会报错。

• 除了 blob ,还有 arraybuffer(把响应体转成 ArrayBuffer ,适合处理纯二进制数据做更底层操作 )、text(转成文本,比如纯文本文件 )等类型,按需选择就能让浏览器用对应方式解析响应。

简单说,responseType: 'blob' 是"告诉浏览器用 Blob 格式解析响应体",让原本的二进制文件流,能以 Blob 对象的形式被前端代码处理,方便后续文件相关的业务逻辑~

相关推荐
树上有只程序猿18 分钟前
终于有人把数据库讲明白了
前端
猩兵哥哥24 分钟前
前端面向对象设计原则运用 - 策略模式
前端·javascript·vue.js
司宸24 分钟前
Prompt设计实战指南:三大模板与进阶技巧
前端
RoyLin27 分钟前
TypeScript设计模式:抽象工厂模式
前端·后端·typescript
华仔啊32 分钟前
Vue3+CSS 实现的 3D 卡片动画,让你的网页瞬间高大上
前端·css
江城开朗的豌豆40 分钟前
解密React虚拟DOM:我的高效渲染秘诀 🚀
前端·javascript·react.js
vivo互联网技术1 小时前
拥抱新一代 Web 3D 引擎,Three.js 项目快速升级 Galacean 指南
前端·three.js
江城开朗的豌豆1 小时前
React应用优化指南:让我的项目性能“起飞”✨
前端·javascript·react.js
会飞的青蛙1 小时前
GIT 配置别名&脚本自动化执行
前端·git