Element-UI使用自定义正则表达式校验

首先,Element-UI已定义了常用的校验,如

<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>

如果,要用自定义的正则表达式来校验,

只需要把上面的

:rules后面换成自己的正则表达式就可以了。如
:rules="[{ required: true, message: '必填项', trigger: 'blur' }, { pattern: "^[0-9]+$", message: '正则表达式只让我输入数字', trigger: ['blur', 'change'] }]"

稍有一点要注意的是,上面的pattern:后面,直接用引号引起来正则表达式,就可以,不需要加两个斜杠。

 

上一篇:Git浅拷贝转换为深拷贝


下一篇:防抖 vue