axios使用注意事项

1、在使用GET方法传递参数时使用的是params,params传参是以/user?ID=1001&name=qq形式传递的;

axios.get('/user?ID=1001')
    .then( res => {
         // 请求数据成功并返回数据。
        console.info(res)
    }).catch( e => {
        console.info(e.config)
    })
// 等同以下写法
axios({
    url: '/user',
    method: 'GET',
    params: {
        ID: 1001
    }
}).then( res => {
    console.info(res)
}).catch( e => {
    console.info(e)
})

2、使用POST时对应的传参使用的是data,data是作为请求体发送的,同样使用这种形式的还有PUT,PATCH等请求方式;

axios.post('/user', {
    firstName: 'Qi',
    lastName: 'Rong'
}).then( res => {
    console.info(res)
}).catch( e => {
    console.info(e)
})
// 等同以下写法
axios({
    url: '/user',
    method: 'POST',
    data: {
        firstName: 'Qi',
        lastName: 'Rong'
    }
}).then( res => {
    console.info(res)
}).catch( e => {
   console.info(e)
})

3、axios中POST的默认请求体类型为Content-Type:application/json,
同时,后台必须要以支持@RequestBody的形式接收参数,否则会出现前台传参正确,后台接收不到的情况;

4、POST如果想要设置类型为Content-Type:application/x-www-form-urlencoded(浏览器原生支持),axios提供了两种方式:
(1)浏览器端,并不是所有浏览器都支持URLSearchParams。

const params = new URLSearchParams();
params.append('firstName', 'Qi');
params.append('lastName', 'Rong');
axios.post('/user', params);

(2)用qs这个库来格式化数据。默认情况下在安装完axios后就可以使用qs库。

const qs = require('qs');
axios.post('/user', qs.stringify({'firstName':'Qi', 'lastName': 'Rong'}));
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 时间2017-03-31 13:43:44Hope’s Blog 原文https://blog.ygxdxx.co...
    萧玄辞阅读 15,255评论 3 16
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,981评论 19 139
  • 年很快就过了,十几天的假里也用掉了新一年全部的年假,小小哀痛下。而日子一晃就是三月,年四分之一的分割线就要划...
    莫名_wxy阅读 210评论 0 0
  • 为鼓励引导“文学陕军”聚焦陕西脱贫攻坚的伟大实践,以文学方式全方位、多角度、深层次反映脱贫攻坚事业,讴歌脱贫攻坚的...
    四叶草文学创作中心阅读 1,936评论 0 0
  • 残雪斑驳映灯火, 清月横笛冷现影, 塞外曲辞追不尽。 春风又绿枝头暖, 浮萍飘零寻根果, 浪迹心近故乡远。
    海风吟雨阅读 303评论 0 0