1. 通过 ref
调用子组件的方法和变量
Vue 3 引入了 ref
,你可以通过 ref
获取子组件实例,并调用其方法或访问其数据。
例子
子组件 (Child.vue
)
<template>
<div>
<p>{{ message }}</p>
<button @click="updateMessage">Update Message</button>
</div>
</template>
<script lang="ts" setup>
import { ref } from 'vue';
// 子组件的响应式数据
const message = ref<string>('Hello from child!');
// 子组件的方法
const updateMessage = () => {
message.value = 'Message updated by child';
};
</script>
父组件 (Parent.vue
)
<template>
<div>
<!-- 通过 ref 引用子组件 -->
<Child ref="childComponent" />
<button @click="callChildMethod">Call Child Method</button>
<p>Message from child: {{ childMessage }}</p>
</div>
</template>
<script lang="ts" setup>
import { ref } from 'vue';
import Child from './Child.vue';
// 父组件引用子组件
const childComponent = ref<typeof Child | null>(null);
const childMessage = ref<string>('');
// 父组件调用子组件的方法
const callChildMethod = () => {
if (childComponent.value) {
// 调用子组件的方法
childComponent.value.updateMessage();
// 获取子组件的数据
childMessage.value = childComponent.value.message;
}
};
</script>
在这个例子中:
- 在父组件中,我们使用
ref="childComponent"
来引用子组件实例。 childComponent.value.updateMessage()
调用子组件的updateMessage
方法。- 子组件的
message
数据被更新后,父组件通过childMessage
变量显示该值。
同样,这种方式可以调用子组件中的变量,这种方式,子组件变量改变时,父组件也会跟着改变
2、延伸
有一次,父组件里MessageItem是在li中循环使用的,想要调用子组件MessageItem里的方法,使用Ref.loadingShowFn(flag)并未取到值,打印发现,因为是循环使用,ref.value是一个多数组,需要遍历取值
<li
v-for="(item, index) in messages"
:key="index"
:id="item?.ID"
ref="messageAimID"
>
<MessageItem
@sendMoreJobMsg="sendMoreJobMsg"
>
</MessageItem>
</li>
const loadingPost = (flag:boolean) => {
mList.value.forEach(childRef => {
if (childRef && childRef.loadingShowFn) {
childRef.loadingShowFn(flag);
}
})
}