axios 常见的content-type、responseType有哪些?

一、Content Type

'Content Type' ,也被称为MIME类型(Multipurpose Internet Mail Extensions),是一种用于标识数据格式的机制。在HTTP协议中,'Content Type'通常通过请求或响应头部的'Content-Type'字段来指定。这个字段的值是一个字符串,用于描述消息体的媒体类型,如文本、图像、音频、视频等,以及可能的字符集和编码方式。当客户端向服务器发送请求时,'Content-Type'头部告诉服务器客户端发送的数据是什么类型,这样服务器就能根据数据的类型来选择合适的处理方式。

在HTTP通信中,有几种常见的'Content Type'类型:

  1. application/json:这是最常见的'Content Type'之一,默认就是json,用于表示JSON格式的数据。JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成。
  2. application/x-www-form-urlencoded​:这是另一种常见的'Content Type',用于表单提交。当表单数据被提交到服务器时,数据会被编码为键值对的形式,并且每个键值对之间用'&'符号分隔。
  3. ​multipart/form-data​ :这种'Content Type'通常用于文件上传。它允许在一个请求中发送多个部分的数据,每个部分都可以有自己的'Content-Type'和'Content-Disposition'等头部信息。
  4. ​text/plain​:这种'Content Type'表示纯文本数据,没有任何格式或编码。

二、responseType

在使用axios进行异步网络请求时,设置正确的responseType类型是非常关键的。axios允许设置多种responseType类型,如'arraybuffer'、'blob'、'document'、'json'、'text'、'stream'。这些类型决定了服务器响应的数据如何被处理和返回。在众多类型中,'json'是最常见的一种,因为它直接返回JavaScript对象,大大简化了数据处理的复杂度。

当你设置responseType为'json'时,axios默认将服务器端返回的数据视为JSON字符串,并自动进行解析。

2.1 理解RESPONSETYPE

responseType属性的设定,直接影响着你如何访问和处理返回的数据。axios通过XMLHttpRequest或fetch(在支持的环境中)对服务器进行请求,而responseType则告诉axios如何解析返回的响应体。

  1. arraybuffer:适用于二进制数据,在处理文件上传下载时尤其有用。
  2. blob:同样用于二进制数据,常在前端需要处理大型二进制对象(如图片或视频文件)时使用。
  3. document:主要用于Web浏览器,允许直接返回一个HTML Document对象。
  4. json:返回一个被解析成JavaScript对象的JSON字符串。大多数API交互使用此类型。
  5. text:返回纯文本字符串。
  6. stream:使用Node.js环境时返回一个流。这对于处理大型数据非常有利。

2.2 应用场景

  1. 处理JSON数据
    处理JSON数据是最常见的场景之一。通过将responseType设置为'json',可以直接获取到JavaScript对象,极大简化了数据处理流程。
js 复制代码
axios.get('your-api-url', {
   responseType: 'json'
}).then(response => {
   console.log(response.data); // 直接访问返回的JavaScript对象
});
  1. 文件下载
    在文件下载场景中,通常需要将responseType设置为'blob'或'arraybuffer'。这样可以处理二进制数据,进而允许用户保存文件到本地。
js 复制代码
axios.get('your-file-url', {
   responseType: 'blob'
}).then(response => {
   const url = window.URL.createObjectURL(new Blob([response.data]));
   const link = document.createElement('a');
   link.href = url;
   link.setAttribute('download', 'your-file-name');
   document.body.appendChild(link);
   link.click();
});
相关推荐
2401_882727571 小时前
低代码配置式组态软件-BY组态
前端·后端·物联网·低代码·前端框架
NoneCoder1 小时前
CSS系列(36)-- Containment详解
前端·css
anyup_前端梦工厂1 小时前
初始 ShellJS:一个 Node.js 命令行工具集合
前端·javascript·node.js
5hand1 小时前
Element-ui的使用教程 基于HBuilder X
前端·javascript·vue.js·elementui
GDAL1 小时前
vue3入门教程:ref能否完全替代reactive?
前端·javascript·vue.js
六卿1 小时前
react防止页面崩溃
前端·react.js·前端框架
z千鑫2 小时前
【前端】详解前端三大主流框架:React、Vue与Angular的比较与选择
前端·vue.js·react.js
m0_748256142 小时前
前端 MYTED单篇TED词汇学习功能优化
前端·学习
小马哥编程3 小时前
Function.prototype和Object.prototype 的区别
javascript
小白学前端6663 小时前
React Router 深入指南:从入门到进阶
前端·react.js·react