vue如何等待axios异步请求完毕之后执行函数

发布于 2022-09-12 00:38:42 字数 382 浏览 9 评论 0

一个按钮触发点击事件,该点击事件触发一个axios请求

<button @click="addData">
    点击
</button>

methods:{
    addData(){
        this.sendData('http://www.xxx.com')
        console.log('ok')
    },
    sendData(url){
        this.axios.post(url).then(...)
    }
}

我想等axios请求完毕后再执行addData中console.log()这个语句,
因为sendData这个函数已经封装好了逻辑,所以不能在.then中修改,请问有什么方法

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

和影子一齐双人舞 2022-09-19 00:38:42
methods:{
    addData(){
        this.sendData('http://www.xxx.com').then(function(){
            console.log('ok')
        })
    },
    sendData(url){
       // ↓这里的then 处理完成后会返回一个 Promise,其中如果没有异常,
       // 其 then return 的值会作为下一次 then 的参数。
       return this.axios.post(url).then(...)
    }
}
彼岸花似海 2022-09-19 00:38:42

methods:{
    async addData(){ //使用async/await 函数
        await this.sendData('http://www.xxx.com') //等待执行完成
        console.log('ok')
    },
    sendData(url){
        return this.axios.post(url).then(...) //这里return还是一个promise
    }
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文