我的 vue 应用程序中有三个组件:
- 家:(巴顿的祖父母)
- 对话框:(家庭的孩子/按钮的父母)
- 按钮:(家的孙子)
该Home组件有一个异步方法:
async handleDialogAccept() {
try {
const response = await this.$axios.get('https://jsonplaceholder.typicode.com/todos/');
console.log(response.data);
} catch (err) {
console.log(err);
}
},
一旦Dialog组件发出“接受”自定义事件,它将立即执行:
<dialog-confirmation
@accept="handleDialogAccept()"
/>
该Dialog组件有一个子 ( Button):
<button-accept
v-on="$listeners"
>
Accept
</button-accept>
在我的buttonAccept.vue哪个被导入Dialog并使用如上所示具有下一个结构:
<template>
<v-btn
color="primary"
@click="handleClick()"
:loading="loading"
:disabled="loading"
>
<slot name="accept"></slot>
</v-btn>
</template>
<script>
export default {
props: ['parentFunction'],
data() {
return {
loading: false,
};
},
methods: {
handleClick() {
this.$emit('accept');
},
},
};
</script>
我想在handleClick方法中执行接下来的步骤:
- 设置
loading为真 - 发出接受自定义事件
- 等到
handleDialogAccept完成 - 设置
loading为假
需要等待吗?