明霞山资源网 Design By www.htccd.com
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的区别详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
明霞山资源网 Design By www.htccd.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
明霞山资源网 Design By www.htccd.com
暂无评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。