vue笔记(五)表单验证

这里以验证两次密码是否一致,来记录vue表单验证写法。

 

一、首先这里使用 Element UI 的表单验证,基本用法如地址:http://element-cn.eleme.io/#/zh-CN/component/form

 

二、然后查看示例代码,了解对应的属性,方法,事件。

 

三、拷贝示例代码然后简化,如下:

    
提交 重置

这里定义了一个form表单,指定了表单数据ruleForm,验证规则demoRules,两个input,根据 Element UI 的要求加上prop(和需要校验的值同名)。

 

四、定义校验规则,如下:

    data () {
      //自定义规则,参数value是校验的值,callback是回调方法,用于显示校验不通过
      let validatePass=(rule,value,callback)=>{
        if(value === null || value === undefined){
          callback(new Error('用户名不能为空'))
        }else{
          //判断第二次输入是否是空,非空则校验第二次输入的内容
          if(this.ruleForm.nameAgain!=='' && this.ruleForm.nameAgain!==undefined){
            this.$refs.ruleForm.validateField('nameAgain')
          }
          callback()
        }
      }
      //判断第二次输入内容和首次输入内容是否一致
      let validatePass2=(rule,value,callback)=>{
        if(value === null || value === undefined){
          callback(new Error('请再次输入'))
        }else if(value !== this.ruleForm.name){
          callback(new Error('两次输入不相同'))
        }else{
          callback()
        }
      }
      return {
        ruleForm:{
        },
        //定义校验规则,一组规则以一个{ }标识,可以通过validator来引用自定义规则
        demoRules:{
          name:[
            {required:true,message:'不能为空',trigger:'blur'},
            {validator:validatePass,trigger:'blur'}
            ],
          nameAgain:[
            {required:true,message:'不能为空',trigger:'blur'},
            {validator:validatePass2,trigger:'blur'}
            ]
        }
      }

    },

校验规则可以多项,以{ }的形式放入数组,这里需要注意的是自定义的校验规则要在demoRules之前定义,否则调用不到。

 

 

 

五,提交时候判断是否校验成功,如下:

      submitBtn:function () {
        this.$refs.ruleForm.validate((valid)=>{
          if(valid){
            console.log('校验通过咯')
          }else{
            console.log('没通过呢')
          }
        })
      },
      resetBtn:function () {
        this.$refs.ruleForm.resetFields();
      }

 

最后简单说一下 ref 和 $refs

 

 

前者可以理解为,通过添加ref ,给节点取了别名,可以通过this.$refs.别名 来调用对应节点。

注:在element ui使用键盘事件时,如keyup,需要额外使用native:@keyup.enter.native="method-name"

效果如下:

vue笔记(五)表单验证_第1张图片

你可能感兴趣的:(vue)