使用axios请求接口,几种content-type的区别详解


Posted in Javascript onOctober 29, 2019

axios的使用

安装(一般使用框架的话, 脚手架都集成了)

$ npm install axios

请求示例

// POST
axios.post('/user', {
 firstName: 'Fred',
 lastName: 'Flintstone'
 })
 .then(function (response) {
 console.log(response);
 })
 .catch(function (error) {
 console.log(error);
 });
// GET
axios.get('/user', {
 params: {
  ID: 12345
 }
 })
 .then(function (response) {
 console.log(response);
 })
 .catch(function (error) {
 console.log(error);
 });
// 执行多个并发
axios.all([get1(), get2()])
 .then(axios.spread(function (acct, perms) {
 // 两个请求现在都执行完成
 }));

可以通过向 axios 传递相关配置来创建请求

语法: axios(config)

axios({
 method: 'post',
 url: '/user/12345',
 data: {
 firstName: 'Fred',
 lastName: 'Flintstone'
 }
});

这里, 我就拿以POST的方式传递相关配置来说事, 因为笔者在这里躺了两次坑, 很有必要记录一下, 哈哈.

默认情况下, 不写content-type, 是以json的方式来传递, (Content-Type: application/json;charset=UTF-8)

axios({
 url:'/api/connect/token',
 method: 'post',
 data: {
   firstName: 'Fred',
   lastName: 'Flintstone'
  }
 }).then(res => {
  console.log(1234, res.data)
 }).catch(error => {
  console.log(error)
 })

Headers如下:

Request Payload
{ firstName: "Fred", lastName: "Flintstone"}

content-type改成x-www-form-urlencoded, 即表单提交方式

axios({
 url:'/api/connect/token',
 method: 'post',
 data: {
   firstName: 'Fred',
   lastName: 'Flintstone'
  },
 headers: {
   'Content-type': 'application/x-www-form-urlencoded'
  }
 }).then(res => {
  console.log(1234, res.data)
 }).catch(error => {
  console.log(error)
 })

Headers如下:

Form Data
{"firstName":"Fred","lastName":"Flintstone"}:

另一种情况, 序列化成字符串形式传递

axios({
 url:'/api/connect/token',
 method: 'post',
 data: JSON.stringify({
   firstName: 'Fred',
   lastName: 'Flintstone'
  })
 }).then(res => {
  console.log(1234, res.data)
 }).catch(error => {
  console.log(error)
 })

结果跟上面一致:

Form Data
{"firstName":"Fred","lastName":"Flintstone"}:

还有一种常见情况, 通过qs库对数据进行编码(前提要安装qs)

import qs from 'qs'
axios({
 url:'/api/connect/token',
 method: 'post',
 data: qs.stringify({
   firstName: 'Fred',
   lastName: 'Flintstone'
  })
 }).then(res => {
  console.log(1234, res.data)
 }).catch(error => {
  console.log(error)
 })

结果:

Request Headers
Content-Type: application/x-www-form-urlencoded
Form Data
firstName: Fred
lastName: Flintstone

使用qs要注意的点 :

allowDots(多层对象嵌套, 可用.标记)

qs.stringify({ 
 a: { 
  b: { 
   c: 'd', e: 'f' 
  } 
 } 
}, { allowDots: true });
// 'a.b.c=d&a.b.e=f'

以上这篇使用axios请求接口,几种content-type的区别详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript while语句和do while语句的区别分析
Dec 08 Javascript
js 模拟气泡屏保效果代码
Jul 10 Javascript
juqery 学习之三 选择器 可见性 元素属性
Nov 25 Javascript
读jQuery之五(取DOM元素)
Jun 20 Javascript
你必须知道的Javascript知识点之"字面量和对应类型"说明介绍
Apr 23 Javascript
jQuery+css3实现Ajax点击后动态删除功能的方法
Aug 10 Javascript
用window.onerror捕获并上报Js错误的方法
Jan 27 Javascript
js简单判断移动端系统的方法
Feb 25 Javascript
jQuery实现Select下拉列表进行状态选择功能
Mar 30 jQuery
解决循环中setTimeout执行顺序的问题
Jun 20 Javascript
在vue项目中引入高德地图及其UI组件的方法
Sep 04 Javascript
JavaScript实现随机点名器实例详解
May 07 Javascript
vue+elementui 对话框取消 表单验证重置示例
Oct 29 #Javascript
vue实现路由监听和参数监听
Oct 29 #Javascript
基于axios 的responseType类型的设置方法
Oct 29 #Javascript
关于vue2强制刷新,解决页面不会重新渲染的问题
Oct 29 #Javascript
vue + elementUI实现省市县三级联动的方法示例
Oct 29 #Javascript
vue 强制组件重新渲染(重置)的两种方案
Oct 29 #Javascript
javascript实现简单打字游戏
Oct 29 #Javascript
You might like
php数组函数序列之array_pop() - 删除数组中的最后一个元素
2011/11/07 PHP
thinkphp模板用法和内容输出实例
2014/11/28 PHP
PHP7.1实现的AES与RSA加密操作示例
2018/06/15 PHP
document.onreadystatechange事件的用法分析
2009/10/17 Javascript
JavaScript Chart 插件整理
2010/06/18 Javascript
九种js弹出对话框的方法总结
2013/03/12 Javascript
打开新窗口关闭当前页面不弹出关闭提示js代码
2013/03/18 Javascript
JavaScript?Apple设备检测示例代码
2013/11/15 Javascript
如何判断微信内置浏览器(通过User Agent实现)
2014/09/01 Javascript
AngularJS 工作原理详解
2016/08/18 Javascript
JavaScript 对象详细整理总结
2016/09/29 Javascript
React Native 集成jpush-react-native的示例代码
2017/08/16 Javascript
vue.extend实现alert模态框弹窗组件
2018/04/28 Javascript
Vue下路由History模式打包后页面空白的解决方法
2018/06/29 Javascript
详解小程序输入框闪烁及重影BUG解决方案
2018/08/31 Javascript
小程序实现列表点赞功能
2018/11/02 Javascript
如何在Vue中使用CleaveJS格式化你的输入内容
2018/12/14 Javascript
微信小程序登录按钮遮罩浮层效果的实现方法
2018/12/16 Javascript
在vue中获取wangeditor的html和text的操作
2020/10/23 Javascript
使用Python编写Linux系统守护进程实例
2015/02/03 Python
约瑟夫问题的Python和C++求解方法
2015/08/20 Python
Python简单实现查找一个字符串中最长不重复子串的方法
2018/03/26 Python
Python单元测试实例详解
2018/05/25 Python
CentOS7下python3.7.0安装教程
2018/07/30 Python
Windows下PyCharm2018.3.2 安装教程(图文详解)
2019/10/24 Python
python实现大战外星人小游戏实例代码
2019/12/26 Python
python如何求圆的面积
2020/07/01 Python
HTML5中的音频和视频媒体播放元素小结
2016/01/29 HTML / CSS
世界排名第一的万圣节服装店:Spirit Halloween
2018/10/16 全球购物
adidas马来西亚官网:adidas MY
2020/09/12 全球购物
Linux操作面试题
2015/02/11 面试题
中式餐厅创业计划书范文
2014/01/23 职场文书
高中毕业典礼演讲稿
2014/09/09 职场文书
离婚协议书范文2014
2014/10/16 职场文书
企业年会祝酒词
2015/08/11 职场文书
初三化学教学反思
2016/02/22 职场文书