axios请求获取到返回值

axios请求获取到返回值


最近在学习Vue,碰到一个问题就是需要从后端获取到某个返回值之后再运行后面的代码。

一般调用axios接口都是这样的格式。

this.$axios.post('api/xxxx/xxxxx', this.$qs.stringify({
    username: 'qwerqw',
    password: '123456'
})).then(res => {
    ...
    ...
}).catch(error => {
    ...
    ...
})

这样的格式要想获取到返回值的话,就要将代码都写在then中,阅读代码的时候不是很清晰。于是网上各种搜,最后觉得这种方法能解决我的强迫症。

login: async function() {
    // result的值就是res.data
    let result = await new Promise((resolve,reject) => {
        this.$axios.post('api/xxxx/xxxxx', this.$qs.stringify({
            username: 'qwerqw',
            password: '123456'
        })).then(res => {
            resolve(res.data)
        }).catch(error => {
            console.log(error)
        })
    })

    ...
    ...
}

按照这种方式去获取到后端的返回值,就可以将剩下的逻辑放在axios请求外面了。
我的理解是,axios是一种异步请求方法,需要用await关键词修饰,等到获取到返回值后再执行后面的代码。在使用await时,需要再function前添加async关键词。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值