详解vue如何使用rules对表单字段进行校验
Posted winifredaf
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了详解vue如何使用rules对表单字段进行校验相关的知识,希望对你有一定的参考价值。
1、在代码中,添加属性::rule
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
< Form ref = "loginForm" :model = "form" :rules = "rules" @ keydown.enter.native = "handleSubmit" class = "form-con" > < FormItem prop = "phone" > < Input v-model = "form.phone" prefix = "md-person" placeholder = "请输入您的手机号" size = "large" class = "login-form-input" :maxlength = "11" ></ Input > </ FormItem > < FormItem prop = "password" > < Input type = "password" v-model = "form.password" prefix = "md-lock" placeholder = "请输入您的密码" size = "large" class = "login-form-input" :maxlength = "100" ></ Input > </ FormItem > < FormItem prop = "code" > < Input v-model = "form.code" placeholder = "请输入验证码" prefix = "ios-barcode" size = "large" class = "login-form-input" :maxlength = "4" ></ Input > < img @ click = "refLoginImg" :src = "loginImgSrc" class = "login-img" /> </ FormItem > < FormItem > < Button @ click = "handleSubmit" :loading = "submitLoading" type = "info" long size = "large" class = "login-btn" icon = "md-log-in" > < span v-if = "!submitLoading" >立即登录</ span > < span v-else>正在登录,请稍候...</ span > </ Button > </ FormItem > </ Form > |
2.新建一个文件(validate.js)定义验证规则
1
2
3
4
5
6
7
8
9
10
11
12
13
|
/** 这个文件只允许放表单验证方法 **/ //验证手机号 export function isPhone(rule, value, callback) { if (!value) { return callback( new Error( ‘输入不可以为空‘ )); } var pattern = /^1[34578]d{9}$/ if (pattern.test(value)){ return callback() } return callback( new Error( ‘输入的手机号错误‘ )) } |
3、在页面(xx.vue)中引入验证规则定义的文件,并在export default中定义rule规则,使用语法:{validator:验证方法,trigger:验证触发} validator
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
rules: { phone: [ { required: true , message: ‘手机号不能为空‘ , trigger: ‘blur‘ }, { type: ‘string‘ , min: 11, message: ‘手机号不允许小于11位‘ , trigger: ‘blur‘ }, { validator: isPhone, trigger: ‘blur‘ }, ], password: [ { required: true , message: ‘密码不能为空‘ , trigger: ‘blur‘ }, { type: ‘string‘ , min: 6, message: ‘密码不允许小于6位‘ , trigger: ‘blur‘ }, ], code: [ { required: true , message: ‘验证码不能为空‘ , trigger: ‘blur‘ }, { type: ‘string‘ , min: 4, message: ‘验证码必须是4位‘ , trigger: ‘blur‘ }, ], }, |
以下是validator.js文件的部分验证方法
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
|
/* 是否是公司邮箱*/ export function isWscnEmail(str) { const reg = /^[a-z0-9](?:[-_.+]?[a-z0-9]+)*@wallstreetcn.com$/i; return reg.test(str.trim()); } /* 合法uri*/ export function validateURL(textval) { const urlregex = /^(https?|ftp)://([a-zA-Z0-9.-]+(:[a-zA-Z0-9.&%$-]+)*@)*((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9][0-9]?)(.(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9])){3}|([a-zA-Z0-9-]+.)*[a-zA-Z0-9-]+.(com|edu|gov|int|mil|net|org|biz|arpa|info|name|pro|aero|coop|museum|[a-zA-Z]{2}))(:[0-9]+)*(/($|[a-zA-Z0-9.,? ‘\+&%$#=~_-]+))*$/; return urlregex.test(textval); } // 验证是否整数 export function isInteger(rule, value, callback) { if (!value) { return callback(new Error(‘ 输入不可以为空 ‘)); } setTimeout(() => { if (!Number(value)) { callback(new Error(‘ 请输入正整数 ‘)); } else { const re = /^[0-9]*[1-9][0-9]*$/; const rsCheck = re.test(value); if (!rsCheck) { callback(new Error(‘ 请输入正整数 ‘)); } else { callback(); } } }, 1000); } // 验证是否是[0-1]的小数 export function isDecimal(rule, value, callback) { if (!value) { return callback(new Error(‘ 输入不可以为空 ‘)); } setTimeout(() => { if (!Number(value)) { callback(new Error(‘ 请输入数字 ‘)); } else { if (value < 0 || value > 1) { callback(new Error(‘ 请输入[0,1]之间的数字 ‘)); } else { callback(); } } }, 1000); } // 验证端口是否在[0,65535]之间 export function isPort(rule, value, callback) { if (!value) { return callback(new Error(‘ 输入不可以为空 ‘)); } setTimeout(() => { if (value == ‘ ‘ || typeof(value) == undefined) { callback(new Error(‘ 请输入端口值 ‘)); } else { const re = /^([0-9]|[1-9]d|[1-9]d{2}|[1-9]d{3}|[1-5]d{4}|6[0-4]d{3}|65[0-4]d{2}|655[0-2]d|6553[0-5])$/; const rsCheck = re.test(value); if (!rsCheck) { callback(new Error(‘ 请输入在[0-65535]之间的端口值‘)); } else { callback(); } } }, 1000); } /* 小写字母*/ export function validateLowerCase(str) { const reg = /^[a-z]+$/; return reg.test(str); } |
以上是关于详解vue如何使用rules对表单字段进行校验的主要内容,如果未能解决你的问题,请参考以下文章
vue 验证表单格式rule和清空表单resetfields