vue3 setup 父页面调用子组件及子组件调用父页面方法的DEMO
父页面调用子组件中方法
父页面
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | < template > < div > <!-- 第四步:页面使用子组件,并添加 ref 属性,注意ref属性不能和子组件重名 --> < role-card ref="roleRef"></ role-card > </ div > </ template > < script lang="ts" setup> import {ref,reactive, Ref} from 'vue' // 第三步:父页面引入子组件 import roleCard from "./role-card.vue"; // 第五步,获取页面的ref属性,用同名属性值接收(因此在第三步不能和子组件同名) let roleRef = ref() // 第六步,使用 [ref].value 调用子组件中的方法 roleRef.value.initData() |
子组件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | < template > < div > 这是一个子组件 </ div > </ template > < script setup lang="ts"> import { ref, Ref, reactive } from 'vue' // 第一步:子组件中声明方法 const initData = async () => { console.log('初始化子组件数据') } // 第二步 重要 :使用 defineExpose 声明父组件要调用的方法 defineExpose({ initData }) </ script > |
子组件调用父页面中方法
子组件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | < template > </ template > < script setup lang="ts"> import { onMounted } from "@vue/runtime-core"; const emit = defineEmits([ "doSth" ]); const doSth = () => { emit('doSth'); } onMounted(() => { doSth(); }); </ script > < style scoped> </ style > |
父页面
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | < template > <!-- 第一步:使用 @do-sth 或 @doSth 接受方法 --> < HelloWorld @doSth="sayHello" /> </ template > < script setup lang="ts"> // 一、导入 import HelloWorld from './components/HelloWorld.vue'; // 二、函数 // 第二步: 自定义方法 const sayHello = () => { console.log("hello world!"); } </ script > < style > </ style > |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· winform 绘制太阳,地球,月球 运作规律
· 上周热点回顾(3.3-3.9)