Vue使用axios发起网络请求,vue组件中发起请求后并未等待结果返回就继续执行

发布于 2022-09-11 17:47:31 字数 625 浏览 10 评论 0

问题如题,我相信这个问题是刚开始学习的时候都会遇到的问题,我再贴一下我的具体代码

vue组件中,发起网络请求,代码如下

clipboard.png

api 中处理方法如下

clipboard.png

chrome中实际输出如下

clipboard.png

我想要的结果是先输出api中logout的 ‘登出成功’ ,返回 success 给请求方,然后却并没有这样,原因我知道,异步的嘛,不过怎么改就不知道了

另外,如果只限这里的解决方案,我也知道,可能有人会叫我直接把vue组中的(也就是接收‘success’后的操作搬到logout中)操作搬到api中,这里是可以这样解决,不过以后总会遇到不适合这种解决方法的情况嘛,所以我还是希望有大佬能给个你们遇到这种情况觉得合适的解决方法

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

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

发布评论

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

评论(3

み零 2022-09-18 17:47:31

应该是把logout方法中的成功回调后的then方法放置于Vue组件中吧

复古式 2022-09-18 17:47:31

logout那里return promise,组件那里用logout.then(...//这里执行你后面的操作),或者用下async,await。

多情癖 2022-09-18 17:47:31

可以使用async函数呀


api.js

logout(){
    return request(...);
}

vue组件

methods: {
    async xxxFun(){
        const result = await this.xxx.api.logout();
    }
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文