vue 表单验证正则_vue elementUI如何自定义表单验证规则

一、elementUI自带了一部分表单验证规则,本文讲解如何使用自定义验证规则来完成密码的二次验证。

1.1、首先添加验证邮箱和电话规则和正则表达式// 验证邮箱的规则

var checkEmail = (rule, value, cb) => {

// 邮箱正则表达式

const regEmail =  /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-])+/

if(regEmail.test(value)){

return cb()

}

cb(new Error('请输入合法的邮箱'))

}

// 验证手机号的规则

var checkTel = (rule, value, cb) => {

const regTel = /^[1](([3][0-9])|([4][0,1,4-9])|([5][0-3,5-9])|([6][2,5,6,7])|([7][0-8])|([8][0-9])|([9][0-3,5-9]))[0-9]{8}$/;

if(regTel.test(value)){

return cb()

}

cb(new Error('请输入合法的电话'))

}

1.2、添加表单验证规则对象,validator绑定checkEmail和checkTel验证规则//添加表单验证规则对象

addFormRules: {

email: [

{required: true, message: '请输入邮箱',trigger: 'blur'},

{validator: checkEmail, trigger: 'blur'}

],

tel: [

{required: true, message: '请输入电话',trigger: 'blur'},

{validator: checkTel, trigger: 'blur'}

]

}

完整代码演示:

验证错误

df489ad95270f97dce5fec38bad5e316.png

验证通过

2ebdd9659468b12e529c8b21661b6e2a.png

二、表单代码:

三、data方法代码data(){

// 验证邮箱的规则

var checkEmail = (rule, value, cb) => {

// 邮箱正则表达式

const regEmail =  /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-])+/

if(regEmail.test(value)){

return cb()

}

cb(new Error('请输入合法的邮箱'))

}

// 验证手机号的规则

var checkTel = (rule, value, cb) => {

const regTel = /^[1](([3][0-9])|([4][0,1,4-9])|([5][0-3,5-9])|([6][2,5,6,7])|([7][0-8])|([8][0-9])|([9][0-3,5-9]))[0-9]{8}$/;

if(regTel.test(value)){

return cb()

}

cb(new Error('请输入合法的电话'))

}

return {

// 获取用户列表的参数对象

queryInfo: {

query: '',

// 当前的页数

pagenum: 1,

// 当前每页显示多少条数据

pagesize: 10

},

UserList: [],

total: 0,

// 控制添加用户对话框的显示和隐藏

addDialogVisible: false,

//添加用户的表单数据

addForm: {

email: '',

tel: ''

},

//添加表单验证规则对象

addFormRules: {

email: [

{required: true, message: '请输入邮箱',trigger: 'blur'},

{validator: checkEmail, trigger: 'blur'}

],

tel: [

{required: true, message: '请输入电话',trigger: 'blur'},

{validator: checkTel, trigger: 'blur'}

]

}

}

},


版权声明:本文为weixin_30205153原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。