vue3中基于AntDesign的Form嵌套表单的校验


场景:在新增数据弹框中有一个form1和组件form2,在点击新增时进行两个表单的校验

在组件表单2中

javascript 复制代码
  const validateForm = () => {
    return new Promise((resolve, reject) => {
      modalFormPopRef.value
        .validate()
        .then((res) => {
          resolve(res);
        })
        .catch((err) => {
          reject(err);
        });
    });
  };
  defineExpose({
    validateForm
  });

在父组件中

javascript 复制代码
  import to from 'await-to-js';
  
  const handleModalOk = async () => {
  
    // 校验表单
    // from1校验
    const [validError] = await to(modalFormRef.value.validate());
    // 组件form2校验
    // 通过组件上的ref属性calendar,获取子组件中的validateForm
    const [validPopError] = await to(calendar.value.validateForm());

    if (validError || validPopError) {
      message.error('表单校验失败,请检查');
      return;
    }
     // 新增逻辑
      handleAdd();
  };
相关推荐
lichenyang453几秒前
ArkUI 票根卡片:PathShape 真挖洞,shadow 沿凹陷外发光
前端
Cache技术分享1 分钟前
432. Java 日期时间 API - 时间工具 TemporalQuery 详解
前端·后端
浮生望5 分钟前
JavaScript 异步编程核心:从同步阻塞到 Promise 事件循环
javascript·promise
如果超人不会飞7 分钟前
TinyVue Radio单选框组件使用指南
vue.js
假如让我当三天老蒯8 分钟前
暂时性死区是否和闭包是相背的呢(自学用)
前端·javascript
渣波8 分钟前
前端开发主页面小技巧
前端·javascript
小林ixn10 分钟前
前端必知:JS同步异步与Promise,终于有人讲明白了!
javascript·面试
柯克七七10 分钟前
我用3个周末重构了公司的前端项目,老板没发现,但同事都来找我要代码了
前端
鲁班小子12 分钟前
Vite resolve.dedupe 使用教程
vue.js·vite
如果超人不会飞13 分钟前
TinyVue Input输入框组件使用指南
vue.js