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;
}
相关推荐
临江仙45510 小时前
前端骚操作:用户还在摸鱼,新版本已悄悄上线!一招实现无感知版本更新通知
前端·vue.js
想个什么名好呢10 小时前
解决uniapp的H5项目uni-popup页面滚动穿透bug
前端
用户938169125536010 小时前
Vue3项目--mock数据
前端
前端加油站10 小时前
一种新HTML 页面转换成 PDF 技术方案
前端·javascript·vue.js
w***Q35010 小时前
Vue打包
前端·javascript·vue.js
有事没事实验室10 小时前
router-link的custom模式
前端·javascript·vue.js
常乐我净61611 小时前
十、路由和导航
前端
Tonychen11 小时前
TypeScript 里 infer 常见用法
前端·typescript
米诺zuo11 小时前
MUI sx prop 中的响应式适配
前端
周尛先森11 小时前
都React 19了,他到底带来了什么?
前端