form 校验多个表单

2023-11-18

有的时候,表单需要拆开多个,这时候就需要校验多个表单

<template>
  <div>
    <div>表单1</div>
    <div class="top">
      <el-form :model="form" ref="form1" :rules="rules" label-width="100px" class="form">
        <el-form-item label="用户名称" prop="aaa">
          <el-input v-model="form.aaa"></el-input>
        </el-form-item>
        <el-form-item label="用户名称" prop="bbb">
          <el-input v-model="form.bbb"></el-input>
        </el-form-item>
        <el-form-item label="用户名称" prop="ccc">
          <el-input v-model="form.ccc"></el-input>
        </el-form-item>
      </el-form>
    </div>

    <div>表单2</div>
    <div class="bottom">
      <el-form :model="form" ref="form2" :rules="rules" label-width="100px" class="form">
        <el-form-item label="用户名称" prop="ddd">
          <el-input v-model="form.ddd"></el-input>
        </el-form-item>
        <el-form-item label="用户名称" prop="eee">
          <el-input v-model="form.eee"></el-input>
        </el-form-item>
        <el-form-item label="用户名称" prop="fff">
          <el-input v-model="form.fff"></el-input>
        </el-form-item>
        <el-button type="primary" @click="btn()">按钮</el-button>
      </el-form>
    </div>
  </div>
</template>

<script>
export default {
  data () {
    return {
      form: {},
      rules: {
        aaa: [
          { required: true, message: '请输入活动名称', trigger: 'blur' }
        ],
        bbb: [
          { required: true, message: '请输入活动名称', trigger: 'blur' }
        ],
        ccc: [
          { required: true, message: '请输入活动名称', trigger: 'blur' }
        ],
        ddd: [
          { required: true, message: '请输入活动名称', trigger: 'blur' }
        ],
        eee: [
          { required: true, message: '请输入活动名称', trigger: 'blur' }
        ],
        fff: [
          { required: true, message: '请输入活动名称', trigger: 'blur' }
        ]
      },
    }
  },
  methods: {
    async btn () {
      let valid = false
      try {
        await Promise.all([this.$refs.form1.validate(), this.$refs.form2.validate()])
        valid = true
      } catch (error) {
        valid = false
      }

      if (valid) {
        console.log('通过')
      }
    }
  }
}
</script>

<style lang="less" scoped>
.bottom {
  margin-top: 30px;
}
</style>

 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

form 校验多个表单 的相关文章