element-ui里的正则表单验证提交大坑

前言

这几天在修改别人的代码时。发现了父子通信的表单提交验证,一看,自己都懵了,怎么用了表单,但是提交的时候全写些判断呢,没办法了,只能改了!

element表单验证提交

1.基础表单验证提交

<el-form :model="numberValidateForm" ref="numberValidateForm" label-width="100px" class="demo-ruleForm">
  <el-form-item
    label="年龄"
    prop="age"
    :rules="[
      { required: true, message: '年龄不能为空'},
      { type: 'number', message: '年龄必须为数字值'}
    ]"
  >
    <el-input type="age" v-model.number="numberValidateForm.age" autocomplete="off"></el-input>
  </el-form-item>
  <el-form-item>
    <el-button type="primary" @click="submitForm('numberValidateForm')">提交</el-button>
    <el-button @click="resetForm('numberValidateForm')">重置</el-button>
  </el-form-item>
</el-form>
<script>
  export default {
    data() {
      return {
        numberValidateForm: {
          age: ''
        }
      };
    },
    methods: {
      submitForm(formName) {
        this.$refs[formName].validate((valid) => {
          if (valid) {
            alert('submit!');
          } else {
            console.log('error submit!!');
            return false;
          }
        });
      },
      resetForm(formName) {
        this.$refs[formName].resetFields();
      }
    }
  }
</script>

像这里的提交都是用的validate
2.带正则的表单验证
刚开始我也像element-ui提供的方法那样写,自定义校验规则的那个列子,但发现用validate提交的时候没有反应,已打印才知道根本没有进入到那一步。贴上代码:
单独写出来的正则验证

并没有进入到打印位置
后面查看文档知道单独写的验证可能需要进行部分校验,需要用的validateField,把需要校验的字段,传到方法里,如下

 this.$refs.formData.validateField(['marter','code'], (valid)=>{
      console.log("拿到东西了吗,进入",valid)
      if(!valid){
        alert("可以")
      }else{
        alert("不可以")
      }
    })

但这样会执行方法两次,并且不能做的我们理想的表单验证方式。
3.完美的表单验证提交
可以把分开写的正则融入到rules里面,element有个属性pattern,专门用来做正则的表单验证,代码如下:

在这里插入代码片
rules:{
 packageSize: [{ message: "字段长度不合格!", trigger: "blur",pattern: /^[1-9]\d{0,6}(\.\d{1,3})?$|^0(\.\d{1,3})?$/ }],
}

在提交的时候也不需要用到validateField,直接跟最普通的提交方法一样,用validate

 this.$refs.formData.validate((valid)=>{
      console.log("拿到东西了吗,进入",valid)

      if(valid){
        alert("可以")
      }else{
        alert("不可以")
      }
    })
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值