-
父组件:
<script setup> import { defineAsyncComponent, watchEffect, toRefs, reactive } from 'vue';// 异步组件
const Test = defineAsyncComponent(()=>import('./xx/Test.vue'))const child1Ref = ref(null)
</script> <template> {{ state.age }} -- {{ state.name }} <button @click="state.sayHello">say hello</button> <Test ref="child1Ref"/> </template>
const state = reactive({
age: 1,
name: '2',
sayHello: null,
})
watchEffect(() => {
// 拿到子组件的一些数据
console.log(child1Ref.value)
const obj = toRefs(child1Ref.value)
console.log(obj.a, obj.b)
state.name = obj.b
state.age = obj.a
state.sayHello = obj.onSayHello
}) -
子组件
<script setup> import { ref, defineExpose } from 'vue'const a = ref(101)
const b = ref('sddewfewfew')const onSayHello = () => {
</script> <template>
console.log('hello')
}
defineExpose({
a,
b,
onSayHello,
})Child1
</template>
vue3通过ref获取子组件defineExpose的数据和方法
qq_427506082023-10-08 8:58
相关推荐
Hilaku几秒前
OpenClaw 很爆火,但没人敢聊它的权限安全🤷♂️ConardLi38 分钟前
OpenClaw 完全指南:这可能是全网最新最全的系统化教程了!丁哥1 小时前
99.9%纯AI 做了一个ICO图标生成器(免费 全尺寸 不限文件大小)2ICO.CN欢迎品鉴兆子龙2 小时前
React Native 完全入门:从原理到实战哇哇哇哇2 小时前
vue3 watch解析SuperEugene2 小时前
Vite 实战教程:alias/env/proxy 配置 + 打包优化避坑|Vue 工程化必备兆子龙2 小时前
一文彻底搞懂 OpenClaw 的架构设计与运行原理(万字长文)leafyyuki2 小时前
用 AI 和 SDD 重构 Vue2 到 Vue3 的实践记录boooooooom2 小时前
别再用错 ref/reactive!90%程序员踩过的响应式坑,一文根治德育处主任2 小时前
『NAS』一句话生成网页,在NAS部署UPage