vue js 多组件异步请求解决方案

46 篇文章 0 订阅
24 篇文章 1 订阅

接口之间异步问题可以采用Promise+async+await
链接https://blog.csdn.net/qq_39816586/article/details/103517416


使用场景:
1.保障用户必须完成自动登录,才调用后续逻辑
2.保障必须完成初始启动,才调用后续逻辑
3.保障先执行onLoad,才调用后续逻辑

举例:
父组件有一个接口A,子组件有一个接口B
两个的接口调用顺序,不是固定的,有时B先执行,有时A先执行
最终目的:A先执行在执行B


父组件A

import Vue from 'vue'

setup(props, context) {
	const getA = async () => {
	    // 赋值全局变量
		Vue.prototype.$checkA = new Promise(resolve => {
		   Vue.prototype.$hasA = resolve
		})
		await request('A')
		// 接口A执行完毕,调用回调
		context.root.$hasA() // vue3写法 this.$hasA() // vue2写法
    }
	return {
		getA
	}
}

子组件B

setup(props, context) {
	const getB = async () => {
	    // 等待接口A先执行完毕,在执行接口B
		await content.root.$checkA // vue3写法  await this.$checkA // vue2写法
		await request('B')
    }
	return {
		getB
	}
}
  • 8
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值