vue + axios 如何处理连续请求。

发布于 2022-09-11 15:37:13 字数 839 浏览 14 评论 0

问题描述

现在有一个场景是:我需要发四个通道的数据请求,即请求完1号通道,有数据将其放进变量map->1,没有数据放空数据到变量map->1。在完成这一个过程之后再请求2号通道,直到4号通道请求完成。再调用完整的处理过的变量map

问题出现的环境背景及自己尝试过哪些方法

我使用过promise:但是promise在请求错误之后就不能再then下一个请求,直接进入catch;
我使用promise.all:但是只要有一个请求错误,就会返回错误,无法实现空数据在map中的站位。

相关代码

// 请把代码文本粘贴到下方(请勿用图片代替代码)

 request("/union/perfomace/getPeformanceName", {})
        .then(function(response1) {
            return request('/union/perfomace/getPeformancePlan', {peformanceName:                           response1.peformanceName[0]});
        })
        .then(function(response2) {
            return request('/union/hall/getHallInfo', {plan: response2.plans[0]});
        });
--------------------- 

你期待的结果是什么?实际看到的错误信息又是什么?

不中断4个请求中的任何一个,直到结束,再调用最后处理过的map变量。

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

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

发布评论

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

评论(4

洛阳烟雨空心柳 2022-09-18 15:37:13

自己封装一下无论如何都走then不就完了么?

function noErrorAxios(axios) {
    return new Promise(reslove => {
        axios.then(reslove).catch(err => reslove())
    })
}
物价感观 2022-09-18 15:37:13

axios.all()有这个方法

暗地喜欢 2022-09-18 15:37:13

没有数据也不该报错走catch啊,顶多返回的数据是null之类的,自己处理下就好了,如果没有数据后端就抛异常这锅怎么也不能前端来背吧

世界和平 2022-09-18 15:37:13

我总结一下需求,如果理解有误请指出。

  1. 顺序发送四个请求,无论对错。
  2. 如果api返回成功,则将返回数据放到map。

3.如果api返回错误,则构造空数据放到map。

以上需求的难点无非是,你所说的,出错之后then funxtion无法执行了。看起来你好像遇到了一个前端代码问题,但根本原因在于,你不应该利用api的错误结果来推导正确的业务数据。错误就是错误,不要在此之上企图做正常数据。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文