vue3.x 父子组件通信是经常会遇到的
今天介绍的是vue3.x子组件调用父组件方法并获取方法的返回值如何实现,
正常首先会想到是方法里面勇return返回值,就能获取到,但是实际是行不通的,要使用callback,废话不多说了,直接上代码
父组件:
<div>
<ChildComponent @getFatherData="getData"></ChildComponent>
</div>
<script lang="ts" setup>
import {ref, reactive, onMounted,nextTick} from 'vue'
import ChildComponent from './childComponent.vue'
const getData = (callback)=>{
let data = Math.random();
//接下来执行一系列逻辑操作之后
callback(data); //返回data值
}
</script>
子组件childComponent.vue
<div>
{{childData}}
<el-button @click="getDataValue()">获取</el-button>
</div>
<script lang="ts" setup>
import {ref, reactive, onMounted,nextTick} from 'vue'
const childData = ref(0);
const emit = defineEmits<{
(event: "getFatherData", data: object): void
}>()
const getDataValue = ()=>{
emit('getFatherData', (val: number) => {childData.value = val });
}
</script>