在vue中循环中调用接口-promise.all();按顺序执行异步处理
【摘要】 大家好,我是码喽的自我修养!今天给大家分享【在vue中循环中调用接口-promise.all();按顺序执行异步处理】,超详细讲解!并提供具体代码帮助大家深入理解,彻底掌握!原创不易,如果能帮助到带大家,欢迎收藏+关注哦 💕
大家好,我是码喽的自我修养!今天给大家分享【在vue中循环中调用接口-promise.all();按顺序执行异步处理】,超详细讲解!并提供具体代码帮助大家深入理解,彻底掌握!原创不易,如果能帮助到带大家,欢迎收藏+关注哦 💕
场景一
数组遍历中每次遍历都需要去请求getStaffCover接口,拿到该接口的结果拼接到数组的每一项,等到数组遍历完之后,拿到拼接好的数组。拼接的数组必须是最终遍历的结果,所以得等到所有的请求结束之后进行操作,使用map可以返回每一次异步请求的Promise合集,注意这里不需要return,然后使用Promise.all等待执行完所有的异步操作,然后才会执行后面的代码
解决
const promise = nv.aiFaceData.items.map(async item => {
const timelines = [];
let cover, name;
!isEmpty(item.existTime.items) &&
item.existTime.items.forEach(val => {
timelines.push({
start: val.startTime,
duration: val.endTime - val.startTime
});
});
if (get(item, 'staffId')) {
cover = await this.getStaffCover(item.staffId);
name = item.staffBase.name;
} else {
name = this.getMobileNumber(item.mobileNumber); //如果不是该组织人员,显示手机号
}
const itemData = {
info: {
name,
cover
},
timelines: cloneDeep(timelines)
};
aiData.push(itemData);
});
await Promise.all(promise);
this.aiData = cloneDeep(aiData);
场景二
用forEach遍历接口请求时,当所有接口都响应完毕后,关闭loading加载
解决
methods: {
handleAdd (arr) {
this.loading = true
const allApi = []
arr.forEach((item, index) => {
const data = {
id: item.id,
name: item.name
}
const oneApi = api.add(data).then(res => {
if (res.error_code === 0) {
this.$message.success(res.msg)
} else {
this.$message.error(res.msg)
}
})
allApi.push(oneApi)
})
Promise.all(allApi).then(() => {
this.loading = false
})
}
}
好了,本文就到这里吧,点个关注再走嘛~
【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)