使用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 相关文章推荐
IE浏览器PNG图片透明效果代码
Sep 02 Javascript
JavaScript获取table中某一列的值的方法
May 06 Javascript
node.js express安装及示例网站搭建方法(分享)
Aug 22 Javascript
bootstrap的3级菜单样式,支持母版页保留打开状态实现方法
Nov 10 Javascript
Sequelize中用group by进行分组聚合查询
Dec 12 Javascript
canvas知识总结
Jan 25 Javascript
jq stop()和:is(:animated)的用法及区别(详解)
Feb 12 Javascript
BootStrap与Select2使用小结
Feb 17 Javascript
javascript基本数据类型和转换
Mar 17 Javascript
vue + any-touch实现一个iscroll 实现拖拽和滑动动画效果
Apr 08 Javascript
Vue实现微信支付功能遇到的坑
Jun 05 Javascript
如何在现代JavaScript中编写异步任务
Jan 31 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
新手菜鸟必读:session与cookie的区别
2013/08/22 PHP
PHP保留两位小数并且四舍五入及不四舍五入的方法
2013/09/22 PHP
PHP开发注意事项总结
2015/02/04 PHP
php实现生成code128条形码的方法详解
2017/07/19 PHP
线路分流自动跳转代码;希望对大家有用!
2006/12/02 Javascript
Prototype 工具函数 学习
2009/07/23 Javascript
用方法封装javascript的new操作符(一)
2010/12/25 Javascript
浅谈javascript中call()、apply()、bind()的用法
2015/04/20 Javascript
javascript单例模式的简单实现方法
2015/07/25 Javascript
nodejs微信公众号支付开发
2016/09/19 NodeJs
jquery对象和DOM对象的相互转换详解
2016/10/18 Javascript
对vue里函数的调用顺序介绍
2018/03/17 Javascript
jQuery实现获取及设置CSS样式操作详解
2018/09/05 jQuery
json_decode 索引为数字时自动排序问题解决方法
2020/03/28 Javascript
JS使用Chrome浏览器实现调试线上代码
2020/07/23 Javascript
vue 解决setTimeOut和setInterval函数无效报错的问题
2020/07/30 Javascript
JS变量提升及函数提升实例解析
2020/09/03 Javascript
vue pages 多入口项目 + chainWebpack 全局引用缩写说明
2020/09/21 Javascript
jQuery实现可以计算进制转换的计算器
2020/10/19 jQuery
Python中apply函数的用法实例教程
2014/07/31 Python
Python3中使用PyMongo的方法详解
2017/07/28 Python
TensorFlow搭建神经网络最佳实践
2018/03/09 Python
Python 类方法和实例方法(@classmethod),静态方法(@staticmethod)原理与用法分析
2019/09/20 Python
关于Python 解决Python3.9 pandas.read_excel(‘xxx.xlsx‘)报错的问题
2020/11/28 Python
基于HTML5的齿轮动画特效
2016/02/29 HTML / CSS
台湾屈臣氏网路商店:Watsons台湾
2020/12/29 全球购物
英国运动风奢侈品购物网站:Maison De Fashion
2020/08/28 全球购物
如何打造一封优秀的留学推荐信
2014/01/25 职场文书
公司离职证明标准范本
2014/10/05 职场文书
党员个人自我评价
2015/03/03 职场文书
会计岗位职责范本
2015/04/02 职场文书
2015年驾驶员工作总结
2015/04/29 职场文书
毕业证明书
2015/06/19 职场文书
初中数学课堂教学反思
2016/02/17 职场文书
pytorch 如何使用batch训练lstm网络
2021/05/28 Python
Python获取字典中某个key的value
2022/04/13 Python