vue + axios 如何处理连续请求。
问题描述
现在有一个场景是:我需要发四个通道的数据请求,即请求完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 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
自己封装一下无论如何都走
then
不就完了么?axios.all()有这个方法
没有数据也不该报错走catch啊,顶多返回的数据是null之类的,自己处理下就好了,如果没有数据后端就抛异常这锅怎么也不能前端来背吧
我总结一下需求,如果理解有误请指出。
3.如果api返回错误,则构造空数据放到map。
以上需求的难点无非是,你所说的,出错之后then funxtion无法执行了。看起来你好像遇到了一个前端代码问题,但根本原因在于,你不应该利用api的错误结果来推导正确的业务数据。错误就是错误,不要在此之上企图做正常数据。