vue3父组件调用子组件方法的思路及实例代码

 更新时间:2025年06月28日 10:16:30   作者:愉快的小跳蛙  
在Vue.js框架中父子组件之间的通信是常见的需求,其中父组件调用子组件的方法是实现特定功能的重要方式,这篇文章主要介绍了vue3父组件调用子组件方法的相关资料,需要的朋友可以参考下

需求:在vue3中需要在父组件调用子组件的方法

思路:通过ref和defineExpose直接暴露给父组件

1.子组件暴露表单验证方法

<template>
  <a-form ref="formRef" :model="formState" :rules="rules">
    <a-form-item label="用户名" name="username">
      <a-input v-model:value="formState.username" />
    </a-form-item>
  </a-form>
</template>

<script setup>
import { ref } from 'vue';

const formRef = ref(); // 表单引用
const formState = ref({ username: '' }); // 表单数据
const rules = { // 验证规则
  username: [{ required: true, message: '请输入用户名' }]
};

// 暴露给父组件的验证方法
const validate = () => formRef.value.validate();

defineExpose({ validate }); // 暴露方法
</script>

2.父组件触发子组件表单验证

<template>
  <ChildForm ref="childFormRef" />
  <a-button @click="handleSubmit">提交</a-button>
</template>

<script setup>
import { ref } from 'vue';
import ChildForm from './ChildForm.vue';

const childFormRef = ref(); // 子组件引用

const handleSubmit = async () => {
  try {
    const values = await childFormRef.value.validate();
    console.log('验证通过,数据:', values);
    // 提交数据逻辑...
  } catch (error) {
    console.log('验证失败', error);
  }
};
</script>

总结 

到此这篇关于vue3父组件调用子组件方法的文章就介绍到这了,更多相关vue3父组件调用子组件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue3中的Refs和Ref详情

    Vue3中的Refs和Ref详情

    这篇文章主要介绍了Vue3中的Refs和Ref,文章围绕Vue3中的Refs和Ref得相关资料应用举例烦人方式展开详细内容,需要的朋友可以参考一下
    2021-11-11
  • vue脚手架项目创建步骤详解

    vue脚手架项目创建步骤详解

    这篇文章主要介绍了vue脚手架项目创建步骤详解,文章讲解的很清晰,初学者可以跟着步骤学习下
    2021-03-03
  • VUE中使用路由router跳转页面多种方式

    VUE中使用路由router跳转页面多种方式

    对于单页应用,官方提供了vue-router进行路由跳转的处理,这篇文章主要给大家介绍了关于VUE中使用路由router跳转页面的多种方式,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-05-05
  • 基于Vue3实现一个简单的方位动画

    基于Vue3实现一个简单的方位动画

    这篇文章主要为大家详细介绍了如何基于Vue3实现一个简单的方位动画,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-02-02
  • vue项目打包发布后接口报405错误的解决

    vue项目打包发布后接口报405错误的解决

    这篇文章主要介绍了vue项目打包发布后接口报405错误的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • ant-design-vue按钮样式扩展方法详解

    ant-design-vue按钮样式扩展方法详解

    这篇文章主要为大家介绍了ant-design-vue按钮样式扩展方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • Vue使用mind-map实现在线思维导图

    Vue使用mind-map实现在线思维导图

    Vue中的Mind-Map通常是指使用Vue.js这个前端框架构建的思维导图组件或库,它可以帮助开发者在Web应用中创建动态、交互式的思维导图,让用户可以直观地组织信息和结构化数据,本文介绍了Vue使用mind-map实现在线思维导图,需要的朋友可以参考下
    2024-07-07
  • webpack安装配置与常见使用过程详解(结合vue)

    webpack安装配置与常见使用过程详解(结合vue)

    这篇文章主要介绍了webpack安装配置与常见使用过程,主要结合vue实现,通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-06-06
  • vue-cli2打包前和打包后的css前缀不一致的问题解决

    vue-cli2打包前和打包后的css前缀不一致的问题解决

    这篇文章主要介绍了vue-cli2打包前和打包后的css前缀不一致的问题解决,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08
  • vue-router使用next()跳转到指定路径时会无限循环问题

    vue-router使用next()跳转到指定路径时会无限循环问题

    这篇文章主要介绍了vue-router使用next()跳转到指定路径时会无限循环问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11

最新评论