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;
}
相关推荐
谷歌开发者几秒前
Web 开发指向标|开发者工具 AI 辅助功能的 5 大实践应用
前端·人工智能
快乐肚皮6 小时前
一文了解XSS攻击:分类、原理与全方位防御方案
java·前端·xss
保护我方头发丶6 小时前
ESP-wifi-蓝牙
前端·javascript·数据库
想学后端的前端工程师6 小时前
【Flutter跨平台开发实战指南:从零到上线-web技术栈】
前端·flutter
老王Bingo6 小时前
Qwen Code + Chrome DevTools MCP,让爬虫、数据采集、自动化测试效率提升 100 倍
前端·爬虫·chrome devtools
董世昌417 小时前
什么是扩展运算符?有什么使用场景?
开发语言·前端·javascript
来杯三花豆奶7 小时前
Vue 3.0 Mixins 详解:从基础到迁移的全面指南
前端·javascript·vue.js
想学后端的前端工程师7 小时前
【React性能优化实战指南:从入门到精通-web技术栈】
前端·react.js·性能优化
白兰地空瓶7 小时前
React Hooks 深度理解:useState / useEffect 如何管理副作用与内存
前端·react.js
cike_y8 小时前
JSP内置对象及作用域&双亲委派机制
java·前端·网络安全·jsp·安全开发