element plus 多个form校验

javascript 复制代码
<template v-for="(itemForm, idx) in cntrAndOogInfos" :key="idx">
   <el-form
      v-show="idx === activeIndex"
      :ref="(el) => bindRef(el, idx)"
      :model="itemForm.oogBaseInfo"
      :rules="oogFormRules"
      label-width="800px"
      label-position="top"
      class="form-container"
      :disabled="isDisabled"
      >
    <el-form-item prop="overallLength">
        <el-input v-model="itemForm.oogBaseInfo.overallLength">
          <template #append>CM</template>
        </el-input>
    </el-form-item>
  </el-form>
</template>
<script lang="ts" setup>
const formRefs = ref<any[]>([]);
const bindRef = (el, index) => {
  if (el) {
    formRefs.value[index] = el; // 元素存在时存入
  } else {
    delete formRefs.value[index]; // 元素销毁时删除(关键)
  }
}
</script>
javascript 复制代码
// 批量校验所有表单
const validateAllForms = async() => {
  if (!formRefs.value || !formRefs.value.length) {
    return false;
  }

  let allValid = true;
  // 遍历所有表单实例
  for (const form of formRefs.value) {
    try {
      await form.validate(); // 逐个校验
    } catch (error) {
      allValid = false; // 只要有一个失败,整体失败
      // 可选:定位到第一个校验失败的表单
      activeIndex.value = formRefs.value.indexOf(form);
      return false
    }
  }
  return allValid;
}
相关推荐
C_心欲无痕5 分钟前
为什么前端项目部署需要 nginx 或 Apache?
前端·nginx·apache
华如锦7 分钟前
MongoDB作为小型 AI智能化系统的数据库
java·前端·人工智能·算法
bug总结8 分钟前
单点登录总结速通
前端
tianxinw10 分钟前
uniapp x + vue3 实现echarts图表
前端·uni-app·vue·echarts
EricLee10 分钟前
2025 年终总结 - Agent 元年
前端·人工智能·后端
xuyuan199812 分钟前
超越Selenium:自动化测试框架Cypress在现代前端测试中的卓越实践(windows版本)环境搭建
前端·windows·cypress
高山上有一只小老虎1 小时前
SpringBoot项目集成thymeleaf实现web
前端·spring boot·后端
求梦8201 小时前
前端八股文【CSS核心面试题库】
前端·css·面试
算法小菜鸟成长心得1 小时前
记录自己第一次将React 编写的前端部署到服务器,实现外网访问
服务器·前端·react.js
怒放的生命19912 小时前
pnpm + Monorepo 使用教程(集成 Vue 3 项目)
前端·vue.js·pnpm·monorepo·前端工程化