element-UI框架使用validate.js的form校验规则(+自定义验证代码)- 应用篇


element-UI除了官方给出的校验规则,还可以自定义(举例如下)

element-UI框架form表单:提交、验证、自定义规则,如何实现?插件化封装?

(官方说明)引入:Form 组件提供了表单验证的功能,只需要通过 rules 属性传入约定的验证规则,并将 Form-Item 的 prop 属性设置为需校验的字段名即可。校验规则参见 async-validator


代码示例:


<template>
	<div id="htmlWrap">
		<el-main>
			<div class="mainbg">
				<el-row class="w1200 pdt100">
					<el-col :span="13">&nbsp;</el-col>
					<el-col :span="9">
						<el-card class="fmbg" :body-style="{ padding: '0px',height: '100%' }" shadow="never">
							<div style="width:100%;height:100%;">
								<div class="title">互联网信息安全后台管理系统</div>
                  <!--<el-form :label-position="labelPosition" label-width="100px" :model="ruleForm2" :rules="rules2" ref="ruleForm2" status-icon>-->
                  <el-form :label-position="labelPosition" label-suffix=":" label-width="100px" :model="ruleForm2" :rules="rules2" ref="ruleForm2" status-icon>
                    <el-form-item label="手机号码" prop="mobile">
                      <el-input v-model="ruleForm2.mobile" size="mini"></el-input>
                    </el-form-item>
                    <div class="tips"></div>
                    <el-form-item label="密码" prop="pass">
                      <el-input type="password" v-model="ruleForm2.pass" size="mini" clearable></el-input>
                    </el-form-item>
                    <div class="tips"></div>
                    <div class="tips"></div>
                    <el-form-item style="margin-top: 10px;">
                      <el-button type="danger" @click="submitForm('ruleForm2')" size="medium">确认登录</el-button>
                      <el-button type="danger" plain size="medium" @click="linkTo('/register')">立即注册</el-button>
                    </el-form-item>
                  </el-form>

							</div>
						</el-card>
					</el-col>
				</el-row>
				<!--copyright-->
				<el-footer>
					<p>安徽省 · 合肥市 · 某某某科技研究所</p>
					<p>Copyright &copy; 1999-2018, ABCDEF.CN, All Rights Reserved</p>
				</el-footer>
				
			</div>
		</el-main>
	</div>
</template>
<script>
  export default {
    data() {
      var validateMobile = (rule, value, callback) => {
        if (value === '') {
          callback(new Error('请输入手机号码'));
        } else if (value !== '13637060395') {
          callback(new Error('手机号码不合法!'));
        } else {
          callback();
        }
      };
      var validatePass = (rule, value, callback) => {
        if (value === '') {
          callback(new Error('请输入密码'));
        } 
        setTimeout(() => {
          if (this.ruleForm2.pass !== '123456') {
            callback(new Error('密码不正确!'));
          }
          callback();
        }, 1000);
      };
      var checkRegCode = (rule, value, callback) => {
        if (!value) {
          return callback(new Error('验证码不能为空'));
        }
        setTimeout(() => {
          if (!Number.isInteger(value)) {
            callback(new Error('请输入数字值'));
          } else {
            if (value < 1000 || value>999999) {
              callback(new Error('验证码必须为4-6位数字'));
            } else {
              callback();
            }
          }
        }, 2000);
      };
      return {
      	labelPosition: 'right',
        ruleForm2: {
          mobile: '',
          pass: '',
          code: ''
        },
        rules2: {
          mobile: [
            { validator: validateMobile, trigger: 'blur' }
          ],
          pass: [
            { validator: validatePass, trigger: 'blur' }
          ],
          code: [
            { validator: checkRegCode, trigger: 'blur' }
          ]
        }
      };
    },
    methods: {
      submitForm(formName) {
        this.$refs[formName].validate((valid) => {
          if (valid) {
            alert('submit!');
            //自定义跳转 ->首页
            let indexHref = '/index';
            window.location.href = indexHref;
            
          } else {
            console.log('error submit!!');
            return false;
          }
        });
      },
      resetForm(formName) {
        this.$refs[formName].resetFields();
      },
      sendCode(formName) {
      	alert('验证码为\n\n123456\n');
      },
      linkTo(formName) {//自定义跳转 ->注册页
      	window.location.href = formName;
      }
    }
  }
</script>

<!--添加“范围”属性:“scoped”来限制CSS到这个组件 -->
<style scoped>
	 ··· 省略 ···
</style>


上述代码中,查看后总结一下几点:

  1. :rules="rules2"

  2. prop="mobile

  3.    // 其中:validateMobile、validatePass、checkRegCode 是自定义的验证函数(如下所示代码 · 接下面代码)
          
           rules2: {
             mobile: [
               { validator: validateMobile, trigger: 'blur' }
             ],
             pass: [
               { validator: validatePass, trigger: 'blur' }
             ],
             code: [
               { validator: checkRegCode, trigger: 'blur' }
             ]
           }
    
    
    
  4. 	// 其中:validateMobile、validatePass、checkRegCode 是自定义的验证函数(接上面代码)
    
          var validateMobile = (rule, value, callback) => {
            if (value === '') {
              callback(new Error('请输入手机号码'));
            } else if (value !== '13637060395') {
              callback(new Error('手机号码不合法!'));
            } else {
              callback();
            }
          };
          var validatePass = (rule, value, callback) => {
            if (value === '') {
              callback(new Error('请输入密码'));
            } 
            setTimeout(() => {
              if (this.ruleForm2.pass !== '123456') {
                callback(new Error('密码不正确!'));
              }
              callback();
            }, 1000);
          };
          var checkRegCode = (rule, value, callback) => {
            if (!value) {
              return callback(new Error('验证码不能为空'));
            }
            setTimeout(() => {
              if (!Number.isInteger(value)) {
                callback(new Error('请输入数字值'));
              } else {
                if (value < 1000 || value>999999) {
                  callback(new Error('验证码必须为4-6位数字'));
                } else {
                  callback();
                }
              }
            }, 2000);
          };
    
    

参考文章:


以上就是关于“ element-UI框架使用validate.js的form校验规则(+自定义验证代码)- 应用篇 ” 的全部内容。

已标记关键词 清除标记
©️2020 CSDN 皮肤主题: 1024 设计师:上身试试 返回首页