Vue3、Element Plus使用v-for循环el-form表单进行校验

在开发中遇到了这样一个需求

有一个form是通过v-for生成出来的,并且数量不确定,每个表单中的字段都需要做校验,就将自己的解决方法记录了下来。

完整代码如下

html 复制代码
<template>
  <div class="for-form">
    <el-button type="primary" @click="addHandle">新 增</el-button>

    <div class="form-box">
      <div class="form-item" v-for="(item, index) in formList" :key="index">
        <el-form :model="item" :rules="rules" label-width="auto" style="max-width: 300px" label-position="top"
          :ref="($event) => handle($event, index)">
          <el-form-item label="名称" prop="name">
            <el-input v-model="item.name" placeholder="请输入名称" />
          </el-form-item>
          <el-form-item label="手机号" prop="phone">
            <el-input v-model="item.phone" placeholder="请输入手机号" />
          </el-form-item>
          <el-form-item label="性别" prop="sex">
            <el-radio-group v-model="item.sex">
              <el-radio :value="1" size="small">男</el-radio>
              <el-radio :value="2" size="small">女</el-radio>
            </el-radio-group>
          </el-form-item>
          <el-form-item label="爱好" prop="hobby" v-if="item.sex == 2">
            <el-input v-model="item.hobby" placeholder="请输入爱好" />
          </el-form-item>
        </el-form>
      </div>
    </div>

    <el-button type="primary" @click="saveHandle">保 存</el-button>
  </div>
</template>

<script setup lang="ts">
import { reactive, toRefs } from 'vue'

const state = reactive({
  form: {} as any,
  formList: [] as any,
  rules: {
    name: [
      { required: true, message: 'Please input Activity name', trigger: 'blur' },
    ],
  },
  formRefs: [] as any
})

const { formList, rules } = toRefs(state)

function addHandle() {
  state.formList.push({
    name: "",
    phone: "",
    sex: 1,
    hobby: "",
  })
}

function handle(e: any, index: any) {
  // 保存下每个ref
  state.formRefs[index] = e
}

async function saveHandle() {
  let isSubmit: boolean[] = []
  // 循环上面记录下来的ref对每个进行校验
  for (const el of state.formRefs) {
    await el.validate((valid: any) => {
      // 每个 ref 校验成功或者失败都以布尔值存储下来
      if (valid) {
        isSubmit.push(true)
      } else {
        isSubmit.push(false)
      }
    })
  }

  // 只有当 isSubmit 存的值全是 true 时表示每个表单都校验成功了
  // 然后就可以提交了
  let has = isSubmit.every(i => i == true)
  if (has) {
    console.log("可以提交")
  }
  console.log(state.formRefs)
  console.log(isSubmit)
}

</script>

<style scoped lang="scss">
.form-box {
  display: flex;
  align-items: flex-start;

  .form-item {
    margin-right: 20px;
  }
}
</style>
相关推荐
小云朵爱编程12 小时前
Vue项目Iconify的使用以及自定义图标,封装图标选择器
前端·javascript·vue.js
l***O52012 小时前
前端路由历史监听,React与Vue实现
前端·vue.js·react.js
滿13 小时前
vue3 elementplus el-table toggleRowSelection使用方法
javascript·vue.js·elementui
Coder-coco14 小时前
点餐|智能点餐系统|基于java+ Springboot的动端的点餐系统小程序(源码+数据库+文档)
java·vue.js·spring boot·小程序·论文·毕设·电子点餐系统
by__csdn15 小时前
Electron+Vite:实现electron + vue3 + ts + pinia + vite高效跨平台开发指南
前端·javascript·vue.js·typescript·electron·node.js·vue
詹姆斯bind16 小时前
基于Div contenteditable 属性 实现一个 “只读” 标签编辑器
vue.js·编辑器·contenteditable
JIngJaneIL17 小时前
远程在线诊疗|在线诊疗|基于java和小程序的在线诊疗系统小程序设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·小程序·毕设·在线诊疗小程序
笙年20 小时前
Vue 作用域插槽
前端·javascript·vue.js
鱼锦0.021 小时前
基于spring+vue把图片文件上传至阿里云oss容器并回显
java·vue.js·spring
zeijiershuai21 小时前
Vue 工程化、ElementPlus 快速入门、ElementPlus 常见组件-表格组件、ElementPlus常见组件-分页条组件
前端·javascript·vue.js