文章目录
- element-UI除了官方给出的校验规则,还可以自定义(举例如下)
- 代码示例:
- 参考文章:
element-UI除了官方给出的校验规则,还可以自定义(举例如下)
element-UI框架form表单:提交、验证、自定义规则,如何实现?插件化封装?
(官方说明)引入:Form 组件提供了表单验证的功能,只需要通过 rules 属性传入约定的验证规则,并将 Form-Item 的 prop 属性设置为需校验的字段名即可。校验规则参见 async-validator
代码示例:
<template>
<div >
<el-main>
<div class="mainbg">
<el-row class="w1200 pdt100">
<el-col :span="13"> </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="" size="mini"></el-input>
</el-form-item>
<div class="tips"></div>
<el-form-item label="密码" prop="pass">
<el-input type="password" v-model="" 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 © 1999-2018, , 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 !== '13000000000') {
callback(new Error('手机号码不合法!'));
} else {
callback();
}
};
var validatePass = (rule, value, callback) => {
if (value === '') {
callback(new Error('请输入密码'));
}
setTimeout(() => {
if (this. !== '123456') {
callback(new Error('密码不正确!'));
}
callback();
}, 1000);
};
var checkRegCode = (rule, value, callback) => {
if (!value) {
return callback(new Error('验证码不能为空'));
}
setTimeout(() => {
if (!(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';
= indexHref;
} else {
('error submit!!');
return false;
}
});
},
resetForm(formName) {
this.$refs[formName].resetFields();
},
sendCode(formName) {
alert('验证码为\n\n123456\n');
},
linkTo(formName) {//自定义跳转 ->注册页
= formName;
}
}
}
</script>
<!--添加“范围”属性:“scoped”来限制CSS到这个组件 -->
<style scoped>
··· 省略 ···
</style>
上述代码中,查看后总结一下几点:
-
:rules="rules2"
-
prop="mobile
-
// 其中:validateMobile、validatePass、checkRegCode 是自定义的验证函数(如下所示代码 · 接下面代码) rules2: { mobile: [ { validator: validateMobile, trigger: 'blur' } ], pass: [ { validator: validatePass, trigger: 'blur' } ], code: [ { validator: checkRegCode, trigger: 'blur' } ] }
-
// 其中:validateMobile、validatePass、checkRegCode 是自定义的验证函数(接上面代码) var validateMobile = (rule, value, callback) => { if (value === '') { callback(new Error('请输入手机号码')); } else if (value !== '13600000000') { callback(new Error('手机号码不合法!')); } else { callback(); } }; var validatePass = (rule, value, callback) => { if (value === '') { callback(new Error('请输入密码')); } setTimeout(() => { if (this. !== '123456') { callback(new Error('密码不正确!')); } callback(); }, 1000); }; var checkRegCode = (rule, value, callback) => { if (!value) { return callback(new Error('验证码不能为空')); } setTimeout(() => { if (!(value)) { callback(new Error('请输入数字值')); } else { if (value < 1000 || value>999999) { callback(new Error('验证码必须为4-6位数字')); } else { callback(); } } }, 2000); };
参考文章:
- 具体使用,请结合上述代码。不再赘述。
- ****文章:Element框架学习笔记-From表单提交
以上就是关于“ element-UI框架使用的form校验规则(+自定义验证代码)- 应用篇 ” 的全部内容。