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;
}
相关推荐
yume_sibai6 小时前
HTML HTML基础(3)
前端·html
米花丶7 小时前
JSBridge安全通信:iOS/Android桥对象差异与最佳实践
前端·webview
萌萌哒草头将军7 小时前
🚀🚀🚀 Oxc 恶意扩展警告;Rolldown 放弃 CJS 支持;Vite 发布两个漏洞补丁版本;Rslib v0.13 支持 ts-go
前端·javascript·vue.js
接着奏乐接着舞。7 小时前
3D地球可视化教程 - 第1篇:基础地球渲染系统
前端·javascript·vue.js·3d·three.js
龙傲天6667 小时前
Scala的面向对象和函数式编程特性 Idea环境搭建和输入输出
前端
蓝色海岛7 小时前
element-ui表格嵌套表格,鼠标移入时样式错乱-问题调研及处理办法
前端
薄雾晚晴8 小时前
Rspack 实战:用 SWC Loader 搞定 JS 兼容(支持 IE 11 + 现代浏览器,兼顾构建速度)
前端·vue.js
恋猫de小郭8 小时前
Flutter 官方 LLM 动态 UI 库 flutter_genui 发布,让 App UI 自己生成 UI
android·前端·flutter
kymjs张涛8 小时前
零一开源|前沿技术周刊 #15
前端·javascript·面试