el-table表单分步验证

<template>
  <div class="box">
   当前步骤 {{step}}
    <div class="form1">
      <el-form :model="form1Data" ref="form1" label-width="130px" :rules="rules">
        <el-form-item prop="name" label="第一步的姓名">
          <el-input v-model="form1Data.name"></el-input>
        </el-form-item>
      </el-form>
    </div>
    <div class="form2">
      <el-form :model="form2Data" ref="form2" label-width="130px" :rules="rules">
        <el-form-item prop="name" label="第二步的姓名">
          <el-input v-model="form2Data.name"></el-input>
        </el-form-item>

      </el-form>
    </div>
    <div class="form3">
      <el-form :model="form3Data" ref="form3" label-width="130px" :rules="rules">
        <el-form-item prop="name" label="第三步的姓名">
          <el-input v-model="form3Data.name"></el-input>
        </el-form-item>
      </el-form>
    </div>
    <el-button type="primary" @click="nextStep">下一步</el-button>
    <el-button @click="resetForm('form2')">重置</el-button>
  </div>
</template>
<script>
  export default {
    data() {
      return {
        step:1,
        submit:false,
        form1Data: {
          name: ''
        },
        form2Data: {
          name: ''
        },
        form3Data: {
          name: ''
        },
        rules: {
          name: [{
              required: true,
              message: '年龄不能为空'
            }
          ]
        }
      };
    },
    methods: {
      nextStep(){
        let list = []
        if(this.step===1){
          this.provali('form1').then((res)=>{
            alert(res)
            this.step++
          }).catch((res)=>{alert(res)})
        }
        if(this.step===2){
           list.push(this.provali('form1'),this.provali('form2'))
           Promise.all(list).then((res)=>{
             alert(res)
           this.step++
           }).catch((res)=>{
             alert(res)
           })
           list=[]
        }
       if(this.step===3){
         list.push(this.provali('form1'),this.provali('form2'),this.provali('form3'))
         Promise.all(list).then((res)=>{
           alert(res)
         }).catch((res)=>{
          alert(res)
         })
       }

      },
      provali(formName){
        return new Promise((resolve,reject)=>{
          this.$refs[formName].validate((valid)=>{
            if(valid){
              resolve(formName+'验证通过')
            }else{
              reject(formName+'验证失败')
            }
          })
        })
      }
      
      ,
      resetForm() {
        this.$refs['form1'].resetFields();
        this.$refs['form2'].resetFields();
        this.$refs['form3'].resetFields();
      }
    }
  }
</script>
<style type="text/css">
.el-input {border: 1px solid #000000;}
</style>

分步骤进行表单验证,点击下一步验证当前步数之前的表单

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值