vue3父组件调用子组件的方法例子
作者:明明白白的明
这篇文章主要给大家介绍了关于vue3父组件调用子组件的方法例子,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
前言
vue3父组件调用子组件的方法是通过expose
和ref
来实现的,我们可以通过expose
来控制父组件可以访问子组件那些的方法和对象,我们将通过setup api
(组合式 api)和option api
(选项式 api)来演示父组件如何调用子组件的方法。
1,组合式API
父组件通过ref定义子组件实例,通过调用实例获得子组件的数据和方法
<!-- 父组件 app.vue --> <template> <div class="itxst"> <!-- 使用 ref 指令关联子组件 --> <child ref="childComp"/> <button @click="onTry">点击试一试</button> </div> </template> <script setup> import { reactive, ref } from "vue"; import child from "./child.vue"; //定义子组件实例,名称要和上面的ref相同 const childComp = ref(null); //访问demo组件的方法或对象 const onTry = () => { //获取到子组件的 title 数据 let msg = childComp.value.state.title; //调用子组件的 play方法 childComp.value.play(); }; </script>
子组件通过defineExpose暴露对象和方法
<!--子组件名称 child.vue --> <template> <div class="itxst"> {{ state.title }} </div> </template> <script setup> import { ref, reactive } from "vue"; //定义一个变量 const state = reactive({ title: "www.itxst.com", }); //定义一个方法 const play = () => { state.title = "你调用了子组件的方法"; }; //暴露state和play方法 defineExpose({ state, play, }); </script>
2,选项式API
<!-- 父组件 app.vue --> <template> <div class="itxst"> <!-- 使用 ref 命令 --> <child ref="childComp"/> <button @click="onClick">点击试一试</button> </div> </template> <script > import child from "./child.vue"; export default { name: "app", //注册组件 components: { child, }, methods: { onClick: function () { //获取到 子组件的 数据 let msg = this.$refs.childComp.message; //执行了子组件的 play方法 this.$refs.childComp.play(); }, }, }; </script>
<!-- 子组件 child.vue --> <template> <div class="itxst"> {{ title }} </div> </template> <script> //选项式默认当前实例是全部暴露 export default { name: "demo", //默认全部暴露 也可以通过expose控制那些需要暴露 //expose: ['play'], data() { return { title: "www.itxst.com", }; }, methods: { play: function () { this.title = "你调用了子组件的方法"; }, }, }; </script>
总结
到此这篇关于vue3父组件调用子组件的文章就介绍到这了,更多相关vue3父组件调用子组件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!