vue3+vant4父组件点击提交并校验子组件form表单

先看效果

代码如下

父组件

复制代码
<template>
  <ChildForm ref="childFormRef" />
  <button @click="validateForm">校验表单</button>
</template>
<script setup>
import { ref } from 'vue';
import ChildForm from './ChildForm.vue';
const childFormRef = ref(null);
const validateForm = async () => {
  if (childFormRef.value) {
    try {
      const isValid = await childFormRef.value.validate();
      console.log('Form valid:', isValid);
    } catch (error) {
      console.error('Validation error:', error);
    }
  }
};
</script>

子组件

复制代码
<!-- ChildForm.vue -->
<template>
    <van-form ref="formRef">
      <!-- 表单项 -->
      <van-field label="账号" name="账号" v-model="pageList.fieldValue" :rules="rules" />
      <van-field
      v-model="pageList.password"
      label="密码"
      name="密码"
      type="password"
      placeholder="请输入密码"
      :rules="[{ required: true, message: '请输入密码' }]"
    />
    </van-form>
  </template>
  <script setup>
  import { ref, defineExpose } from 'vue';
  const formRef = ref(null);
  let pageList = ref({
    fieldValue:'',
    password:'',
  })
  const rules = ref([
    { required: true, message: 'This field is required' }
  ]);
  
  const validate = async () => {
    if (formRef.value) {
      try {
        await formRef.value.validate();
        return true;
      } catch (error) {
        return false;
      }
    }
    return false;
  };
  defineExpose({ validate });
  </script>

父组件通过ref获取子组件的引用,在父组件的点击事件中调用子组件的validate方法进行表单验证,如果验证通过则执行提交逻辑。子组件通过defineExpose暴露其validate方法给父组件使用。这样父组件就可以通过childForm.value.validate调用子组件的验证方法了。

相关推荐
程序员爱钓鱼39 分钟前
Go操作Excel实战详解:github.com/xuri/excelize/v2
前端·后端·go
子兮曰9 小时前
async/await高级模式:async迭代器、错误边界与并发控制
前端·javascript·github
恋猫de小郭9 小时前
2026 Flutter VS React Native ,同时在 AI 时代 VS Native 开发,你没见过的版本
android·前端·flutter
GIS之路11 小时前
ArcGIS Pro 中的 Notebooks 入门
前端
IT_陈寒13 小时前
React状态管理终极对决:Redux vs Context API谁更胜一筹?
前端·人工智能·后端
lemon_yyds13 小时前
《vue 2 升级vue3 父组件 子组件 传值: value 和 v-model
vue.js
Kagol14 小时前
TinyVue 支持 Skills 啦!现在你可以让 AI 使用 TinyVue 组件搭建项目
前端·agent·ai编程
柳杉14 小时前
从零打造 AI 全球趋势监测大屏
前端·javascript·aigc
simple_lau14 小时前
Cursor配置MasterGo MCP:一键读取设计稿生成高还原度前端代码
前端·javascript·vue.js
睡不着先生14 小时前
如何设计一个真正可扩展的表单生成器?
前端·javascript·vue.js