【vue2】记录mounted里面某三个接口调完之后才能执行其他方法的写法

背景

vue2,异步操作并行运行

需求

某个页面现时需要一些接口请求回来的枚举值作为查询条件可供选择,然后将这些查询条件作为入参,请求列表数据。这就造成了我需要先调用枚举值接口,等枚举值接口调用完了,再调查询接口。

错误示例1

如下代码,我希望等this.getMapList()里面的接口全部调用完成后,再执行 this.handleMapData()和 thi.getList()。

async mounted() {await this.getMapList()this.handleMapData()this.getList()
},
methods() {// 这两是枚举值接口getIndustryList() {service.queryIndustryStyleList().then(res => {this.industryStyleList = res.resultconsole.log(this.industryStyleList, 'industryStyleList')resolve()}).catch(err => {console.log('111', err)this.industryStyleList = []EMessage(err.error_info, 'error')})},getInvestList() {service.queryInvestStyleList().then(res => {this.investStyleList = res.result }).catch(err => {console.log('222', err)this.investStyleList = []EMessage(err.error_info, 'error')})},getMapList() {this.getIndustryList()this.getInvestList()},// 这是列表接口getList() {service.queryTableList({...this.form,}).then(res => {this.tableData = res.result}).catch(() => {this.tableData = []}) },// 这是处理枚举值数据的方法handleMapData() {this.industryStyleList = ...this.investStyleList = ...}
},

我通常会像上面那样写,一直以来都没有什么问题,getList接口都是在两个枚举值接口之后调用的。但这次枚举值接口没通的情况下,我发现在对枚举值数据做处理的this.handleMapData()会先于this.getMapList()执行,这可能会出现不能及时更新枚举值数据。

错误示例2

我尝试把this.getMapList()放在created里面,期待created比mounted先调用,这样就可以保证 this.handleMapData()和 this.getList()一定是在后执行的了

async created() {await this.getMapList()},
async mounted() {this.handleMapData()this.getList()
},

但是!!!在vue的生命周期钩子中,created 和 mounted 是两个不同阶段的钩子,created 先于 mounted,且它们是异步执行的。尽管created的await会暂停created内部代码的执行知道getMapList解决,但这并不影响mounted的执行时机。created钩子中的await只会影响created钩子内的代码执行顺序,mounted钩子会按预期在created后执行,而不会等待created钩子中的异步操作完成。

正确写法

1、首先要确保this.getMapList()里面的两个接口是异步执行的,因为他两谁快谁谁慢都无所谓,只要在this.handleMapData()执行前拿到数据就行。所以getInvestList和getIndustryList的接口调用绝对不能使用try catch,因为那样会造成必须等getIndustryList执行完才能执行getInvestList

2、我期望并行的运行getInvestList和getIndustryList,并等待他们全部全部完成。这就可以用Promise.all()

3、Promise.all()接受一个promise数组作为输入,并会返回一个新的promise,这个新的promise会在所有输入的promise都成功解决后解决,其解决值是一个数组,包含了所有输入promise的解决值(按相同的顺序),如果输入的任何一个promise被拒绝,则返回的promise会立即被拒绝,并带有第一个被拒绝的理由。

4、由于Promise.all()输入的一个promise被拒绝,但其他promise可能成功,所以我选择把在每个请求的.catch中做错误处理,这样无论Promise.all()里的请求是否成功,都会在全部完成后执行this,handleMapData()和this.getList()

async mounted() {try {const promises = [  // 必须在这.catch,这样才能无论成功与否都执行handleMapData和getListthis.getIndustryList().catch(() => {}),  	this.getInvestList().catch(() => {}),  ]await Promise.all(promises)this.handleMapData()this.getList()}catch(err) {}
},
methods: {getIndustryList() {return service.queryIndustryStyleList().then(res => {this.industryStyleList = res.result}).catch(err => {console.log('111', err)this.industryStyleList = []EMessage(err.error_info, 'error')})},getInvestList() {return service.queryInvestStyleList().then(res => {this.investStyleList = res.result }).catch(err => {console.log('222', err)this.investStyleList = []EMessage(err.error_info, 'error')})},// 这是列表接口getList() {service.queryTableList({...this.form,}).then(res => {this.tableData = res.result}).catch(() => {this.tableData = []}) },// 这是处理枚举值数据的方法handleMapData() {this.industryStyleList = ...this.investStyleList = ...}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/42140.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Docker部署Seata与Nacos整合

本文来自 Apache Seata官方文档,欢迎访问官网,查看更多深度文章。 本文来自 Apache Seata官方文档,欢迎访问官网,查看更多深度文章。 Docker部署Seata与Nacos整合 Docker 部署 Seata 与 Nacos 整合 运行所使用的 demo项目地址 …

提升系统稳定性:熔断、降级和限流策略详解

文章目录 前言一、熔断(Circuit Breaker)二、降级(Degradation)三、限流(Rate Limiting)四、应用案例五、小结推荐阅读 前言 随着互联网业务的快速发展,系统稳定性和高可用性成为现代分布式系统…

RedHat9 | Zabbix-Server监控服务部署

系统版本以及软件版本 使用的系统版本: Red Hat Enterprise Linux release 9.2 软件版本: zabbix-release-7.0-3.el9.noarchzabbix-web-7.0.0-release1.el9.noarchzabbix-web-mysql-7.0.0-release1.el9.noarchzabbix-web-deps-7.0.0-release1.el9.noar…

路径规划之基于二次规划的路径平滑Matlab代码

参考: 自动驾驶决策规划算法第二章第二节(上) 参考线模块_哔哩哔哩_bilibili 自动驾驶决策规划算法第二章第二节(下) 参考线代码实践_哔哩哔哩_bilibili QP函数,二次规划的逻辑 function [smooth_path_x,smooth_path_y] QP(path_x, path_y, w_cost_s…

STM32嵌入式工业机器人控制系统教程

目录 引言环境准备工业机器人控制系统基础代码实现:实现工业机器人控制系统 4.1 数据采集模块 4.2 数据处理与分析 4.3 运动控制系统实现 4.4 用户界面与数据可视化应用场景:工业自动化与优化问题解决方案与优化收尾与总结 1. 引言 工业机器人控制系统…

element表格高度撑开div滚动失效解决方案

描述&#xff1a;当显示区域小于表格列表显示内容时 列表完全撑开表格 无法触发el-table组件的滚动事件 解决&#xff1a;包裹表格的div&#xff0c;加上display: flex;flex-direction: column;即可 <template><div class"table-wrap table-scrollable"&g…

Bahdanau 注意力中上下文变量 ′的公式解释

公式 (10.4.1) 是 Bahdanau 注意力模型中的一个关键公式&#xff0c;用于计算在解码时间步 ( t’ ) 的上下文变量 (\mathbf{c}_{t’})&#xff1a; [ \mathbf{c}{t’} \sum{t1}^T \alpha(\mathbf{s}_{t’ - 1}, \mathbf{h}_t) \mathbf{h}_t ] 下面对公式进行详细解释&#x…

【pytorch18】Logistic Regression

回忆线性回归 for continuous:y xwbfor probability output:yσ(xwb) σ:sigmoid or logistic 线性回归是简单的线性模型&#xff0c;输入是x&#xff0c;网络参数是w和b&#xff0c;输出是连续的y的值 如何把它转化为分类问题?加了sigmoid函数&#xff0c;输出的值不再是…

开闭原则的简单总结

简介 开闭原则指的是软件实体(类、模块、函数等)应该对扩展开放,对修改关闭。这意味着: 对扩展开放:当需要新增功能时,可以通过添加新的代码来实现,而不是修改现有代码。对修改关闭:已经存在的、经过测试的代码不应该被修改。 优缺点 优点: 提高代码的可维护性和复用性降低…

java-HashSet 源码分析 1

## 深入分析 Java 中的 HashSet 源码 HashSet 是 Java 集合框架中的一个重要类&#xff0c;它基于哈希表实现&#xff0c;用于存储不重复的元素。HashSet 允许 null 元素&#xff0c;并且不保证元素的顺序。本文将详细分析 HashSet 的源码&#xff0c;包括其数据结构、构造方法…

2024阿里国际春招笔试

第一题 0 解题思路&#xff1a; 数据范围很大&#xff0c;肯定得找规律。 当n1时&#xff0c;0&#xff0c;1&#xff0c;结果为0 当n2时&#xff0c;00&#xff0c;01&#xff0c;10&#xff0c;11&#xff0c;结果为1 当n3时&#xff0c;000&#xff0c;001&#xff0c;010&a…

AWS IoT Core 权限管理指南

AWS IoT Core 是一项托管云服务,允许连接设备安全地与云应用程序和其他设备进行交互。有效管理 IoT Core 的权限对于确保设备和数据的安全至关重要。本文将详细介绍 IoT Core 的常用权限分类,并提供相应的 JSON 策略示例。 1. 概述 IoT Core 的权限可以大致分为以下几类: …

【算法笔记自学】第 3 章 入门篇(1)——入门模拟

3.1简单模拟 自己写的题解 #include <stdio.h> #include <stdlib.h> int main() {int N;int num0;scanf("%d",&N);while(N!1){if(N%20){NN/2;}else{N(3*N1)/2;}num;}printf("%d",num);system("pause"); // 防止运行后自动退出&…

Linux网络管理

一、linux网络管理 1.获取计算机的网络信息 基本语法&#xff1a; #ifconfig #ip address &#xff08;ip a&#xff09; 解析&#xff1a; ens33&#xff1a;默认网卡 lo&#xff1a;环回网卡&#xff0c;127.0.0.1作为固定ip代表本机 virbr0&#xff1a;虚拟网络接口&…

三维轮廓仪测粗糙度:光学3D表面轮廓仪功能详解

在精密制造领域&#xff0c;表面粗糙度的测量是确保产品质量的关键步骤。光学3D表面轮廓仪为这一需求提供了解决方案。 在半导体制造、3C电子、光学加工等高精度行业&#xff0c;表面粗糙度的测量精度直接影响到产品的性能和可靠性。光学3D表面轮廓仪正是为了满足这一需求而设计…

MIPI D-PHY、C-PHY VCX虚拟通道详解

在MIPI CSI-2协议中,VCX(Virtual Channel Extension)是一个重要的字段,用于扩展虚拟通道标识符(Virtual Channel Identifier, VC)的大小,以便在数据流中区分更多的逻辑数据通道。 虚拟通道说明: 1. VCX的作用 扩展VC字段:VC字段在数据标识符(Data Identifier, DI)…

以腾讯为例,手把手教你搭建产品帮助中心

一个精心设计的产品帮助中心对于提高用户满意度和体验至关重要。腾讯&#xff0c;作为全球领先的互联网企业&#xff0c;通过其多样化的产品线&#xff08;包括微信、QQ、腾讯游戏、腾讯视频等&#xff09;吸引了亿万用户。下面将以腾讯为例&#xff0c;向您展示如何搭建一个高…

《python程序语言设计》2018版第5章第51题利用turtle画18x18的格子

05.51.01version 先从第一一个格子来做 turtle.right(45) turtle.circle(18, steps4) turtle.hideturtle() turtle.done()这个代码很简单的现实出格子的样式。 现在的问题是循环的话。首先角度45度怎么处理 随着45度一次一次迭代。他是应该转4590呢还是4545呢&#xff1f;&…

《QT从基础到进阶·四十三》QPlugin插件多线程问题和只有插件dll没有头文件和lib文件时调用插件中的方法

1、插件和多线程问题&#xff1a; 创建插件对象不能放到多线程执行&#xff0c;不然报错&#xff1a;ASSERT failure in QWidget: "Widgets must be created in the GUlthread. //不能放在多线程执行 QPluginLoader pluginLoader(pluginsDir.absoluteFilePath(fileName))…

pandas中 groupby分组详解 1

引言 在一个使用 pandas 做数据分析的项目过程中&#xff0c;再次深刻理解了一下 pandas 中使用 groupby 进行分组的一些细节问题&#xff0c;以及对想要做的操作如何实现&#xff0c;在此记录&#xff1b; 问题 1&#xff1a;groupby 分组查看分组结果&#xff0c;以及重设分…