vue 使用rules对表单字段进行校验的步骤


Posted in Vue.js onDecember 25, 2020

在实际开发过程中,发现以下的写法比较累赘,因为在后面的项目中,继续优化表单验证的方法,让代码更简洁。主要的修改是验证方法的修改和调用

以前验证表单字段的最大长度,description: [{ max: 200, message: '最大长度为200个字符', trigger: 'blur' }]

现在写法:description: [validateLen(200)]

其中,validateLen是我封装的一个方法。

使用步骤:

1、在uitls文件夹中新建一个validate.js文件。

2、定义需要验证的方法

3、在需要使用的页面中引入import { validateLen, validateChart_ } from '@/utils/validate'

4、在用于校验的rules中使用。例如:description: [validateLen(200)]

具体写法:参考如下。只是把旧的写法统一封装成了return 进行输出。少写很多代码,省事整洁

// 是否必填
export function validateNecessary(tipInfo = '请输入', trigger = 'blur', isNeces = true,) {
 return {
  required: isNeces,
  message: tipInfo,
  trigger
 }
}

// 验证最大长度
export function validateLen(len = 20) {
 return {
  max: len,
  message: '最大长度为' + len + '个字符',
  trigger: 'blur'
 }
}

基于element-ui

1、在代码中,添加属性::rule

<el-form :model="form" :rules="rules" ref="form" label-width="150px"></el-form>

并且,在<el-form-item>中添加prop属性,对应rules中的规则

vue 使用rules对表单字段进行校验的步骤

2、新开一个文件夹(validate.js)定义验证规则

vue 使用rules对表单字段进行校验的步骤

3、在页面(index.vue)中引入验证规则定义的文件,并在export default中定义rule规则,使用语法:{validator:验证方法,trigger:验证触发}

vue 使用rules对表单字段进行校验的步骤

4、以下是validator.js文件的部分验证方法

/*是否合法IP地址*/
export function validateIP(rule, value,callback) {
 if(value==''||value==undefined||value==null){
  callback();
 }else {
  const reg = /^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])$/;
  if ((!reg.test(value)) && value != '') {
   callback(new Error('请输入正确的IP地址'));
  } else {
   callback();
  }
 }
}

/* 是否手机号码或者固话*/
export function validatePhoneTwo(rule, value, callback) {
 const reg = /^((0\d{2,3}-\d{7,8})|(1[34578]\d{9}))$/;;
 if (value == '' || value == undefined || value == null) {
  callback();
 } else {
  if ((!reg.test(value)) && value != '') {
   callback(new Error('请输入正确的电话号码或者固话号码'));
  } else {
   callback();
  }
 }
}
/* 是否固话*/
export function validateTelphone(rule, value,callback) {
 const reg =/0\d{2}-\d{7,8}/;
 if(value==''||value==undefined||value==null){
  callback();
 }else {
  if ((!reg.test(value)) && value != '') {
   callback(new Error('请输入正确的固话(格式:区号+号码,如010-1234567)'));
  } else {
   callback();
  }
 }
}
/* 是否手机号码*/
export function validatePhone(rule, value,callback) {
 const reg =/^[1][3,4,5,7,8][0-9]{9}$/;
 if(value==''||value==undefined||value==null){
  callback();
 }else {
  if ((!reg.test(value)) && value != '') {
   callback(new Error('请输入正确的电话号码'));
  } else {
   callback();
  }
 }
}
/* 是否身份证号码*/
export function validateIdNo(rule, value,callback) {
 const reg = /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/;
 if(value==''||value==undefined||value==null){
  callback();
 }else {
  if ((!reg.test(value)) && value != '') {
   callback(new Error('请输入正确的身份证号码'));
  } else {
   callback();
  }
 }
}
/* 是否邮箱*/
export function validateEMail(rule, value,callback) {
 const reg =/^([a-zA-Z0-9]+[-_\.]?)+@[a-zA-Z0-9]+\.[a-z]+$/;
 if(value==''||value==undefined||value==null){
  callback();
 }else{
  if (!reg.test(value)){
   callback(new Error('请输入正确的邮箱地址'));
  } else {
   callback();
  }
 }
}
/* 合法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 isPassword(rule, value, callback) {
 const reg =/^[_a-zA-Z0-9]+$/;
 if(value==''||value==undefined||value==null){
  callback();
 } else {
  if (!reg.test(value)){
   callback(new Error('密码仅由英文字母,数字以及下划线组成'));
  } else {
   callback();
  }
 }
}

/*自动检验数值的范围*/
export function checkMax20000(rule, value, callback) {
 if (value == '' || value == undefined || value == null) {
  callback();
 } else if (!Number(value)) {
  callback(new Error('请输入[1,20000]之间的数字'));
 } else if (value < 1 || value > 20000) {
  callback(new Error('请输入[1,20000]之间的数字'));
 } else {
  callback();
 }
}

//验证数字输入框最大数值,32767
export function checkMaxVal(rule, value,callback) {
 if (value < 0 || value > 32767) {
  callback(new Error('请输入[0,32767]之间的数字'));
 } else {
  callback();
 }
}
//验证是否1-99之间
export function isOneToNinetyNine(rule, value, callback) {
 if (!value) {
  return callback(new Error('输入不可以为空'));
 }
 setTimeout(() => {
  if (!Number(value)) {
   callback(new Error('请输入正整数'));
  } else {
   const re = /^[1-9][0-9]{0,1}$/;
   const rsCheck = re.test(value);
   if (!rsCheck) {
    callback(new Error('请输入正整数,值为【1,99】'));
   } else {
    callback();
   }
  }
 }, 0);
}

// 验证是否整数
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();
   }
  }
 }, 0);
}
// 验证是否整数,非必填
export function isIntegerNotMust(rule, value, callback) {
 if (!value) {
  callback();
 }
 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('请输入[0,1]之间的数字'));
  } else {
   if (value < 0 || value > 1) {
    callback(new Error('请输入[0,1]之间的数字'));
   } else {
    callback();
   }
  }
 }, 100);
}

// 验证是否是[1-10]的小数,即不可以等于0
export function isBtnOneToTen(rule, value, callback) {
 if (typeof value == 'undefined') {
  return callback(new Error('输入不可以为空'));
 }
 setTimeout(() => {
  if (!Number(value)) {
   callback(new Error('请输入正整数,值为[1,10]'));
  } else {
   if (!(value == '1' || value == '2' || value == '3' || value == '4' || value == '5' || value == '6' || value == '7' || value == '8' || value == '9' || value == '10')) {
    callback(new Error('请输入正整数,值为[1,10]'));
   } else {
    callback();
   }
  }
 }, 100);
}
// 验证是否是[1-100]的小数,即不可以等于0
export function isBtnOneToHundred(rule, value, callback) {
 if (!value) {
  return callback(new Error('输入不可以为空'));
 }
 setTimeout(() => {
  if (!Number(value)) {
   callback(new Error('请输入整数,值为[1,100]'));
  } else {
   if (value < 1 || value > 100) {
    callback(new Error('请输入整数,值为[1,100]'));
   } else {
    callback();
   }
  }
 }, 100);
}
// 验证是否是[0-100]的小数
export function isBtnZeroToHundred(rule, value, callback) {
 if (!value) {
  return callback(new Error('输入不可以为空'));
 }
 setTimeout(() => {
  if (!Number(value)) {
   callback(new Error('请输入[1,100]之间的数字'));
  } else {
   if (value < 0 || value > 100) {
    callback(new Error('请输入[1,100]之间的数字'));
   } else {
    callback();
   }
  }
 }, 100);
}

// 验证端口是否在[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();
   }
  }
 }, 100);
}
// 验证端口是否在[0,65535]之间,非必填,isMust表示是否必填
export function isCheckPort(rule, value, callback) {
 if (!value) {
  callback();
 }
 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();
   }
  }
 }, 100);
}

/* 小写字母*/
export function validateLowerCase(str) {
 const reg = /^[a-z]+$/;
 return reg.test(str);
}
/*保留2为小数*/
export function validatetoFixedNew(str) {
 return str ;
}
/* 验证key*/
// export function validateKey(str) {
//   var reg = /^[a-z_\-:]+$/;
//   return reg.test(str);
// }

/* 大写字母*/
export function validateUpperCase(str) {
 const reg = /^[A-Z]+$/;
 return reg.test(str);
}

/* 大小写字母*/
export function validatAlphabets(str) {
 const reg = /^[A-Za-z]+$/;
 return reg.test(str);
}

以上就是vue 使用rules对表单字段进行校验的步骤的详细内容,更多关于vue 用rules对表单字段进行校验的资料请关注三水点靠木其它相关文章!

Vue.js 相关文章推荐
对vue生命周期的深入理解
Dec 03 Vue.js
Vue页面渲染中key的应用实例教程
Jan 12 Vue.js
vue实现验证用户名是否可用
Jan 20 Vue.js
vue穿梭框实现上下移动
Jan 29 Vue.js
vue仿携程轮播图效果(滑动轮播,下方高度自适应)
Feb 11 Vue.js
Vue基本指令实例图文讲解
Feb 25 Vue.js
vue中三级导航的菜单权限控制
Mar 31 Vue.js
使用这 6个Vue加载动画库来减少我们网站的跳出率
May 18 Vue.js
vue 实现上传组件
May 31 Vue.js
Vue3.0写自定义指令的简单步骤记录
Jun 27 Vue.js
vue实现列表拖拽排序的示例代码
Apr 08 Vue.js
Vue操作Storage本地化存储
Apr 29 Vue.js
vue 实现基础组件的自动化全局注册
Dec 25 #Vue.js
vue 使用class创建和清除水印的示例代码
Dec 25 #Vue.js
基于vue+echarts数据可视化大屏展示的实现
Dec 25 #Vue.js
vue3使用vue-count-to组件的实现
Dec 25 #Vue.js
vue+openlayers绘制省市边界线
Dec 24 #Vue.js
vue项目中openlayers绘制行政区划
Dec 24 #Vue.js
Vue+penlayers实现多边形绘制及展示
Dec 24 #Vue.js
You might like
用PHP实现ODBC数据分页显示一例
2006/10/09 PHP
分享PHP入门的学习方法
2007/01/02 PHP
PHP 多维数组排序(usort,uasort)
2010/06/30 PHP
PHP中对用户身份认证实现两种方法
2011/06/04 PHP
鸡肋的PHP单例模式应用详解
2013/06/03 PHP
PHP中抽象类、接口的区别与选择分析
2016/03/29 PHP
php实现获取农历(阴历)、节日、节气的类与用法示例
2017/11/20 PHP
详解laravel passport OAuth2.0的4种模式
2019/11/04 PHP
javascript两段代码,两个小技巧
2010/02/04 Javascript
Jquery 的扩展方法总结
2011/10/01 Javascript
关于锚点跳转及jQuery下相关操作与插件
2012/10/01 Javascript
jquery 清空file域示例(兼容个浏览器)
2013/10/11 Javascript
js日期对象兼容性的处理方法
2014/01/28 Javascript
jQuery性能优化技巧分析
2015/02/20 Javascript
jQuery提示插件alertify使用指南
2015/04/21 Javascript
BootstrapValidator实现注册校验和登录错误提示效果
2017/03/10 Javascript
JS简单获取日期相差天数的方法
2017/04/24 Javascript
vue.js移动端app实战1:初始配置详解
2017/07/24 Javascript
不使用JavaScript实现菜单的打开和关闭效果demo
2018/05/01 Javascript
Vue使用NPM方式搭建项目
2018/10/25 Javascript
Openlayers实现距离面积测量
2020/09/28 Javascript
[04:11]DOTA2亚洲邀请赛小组赛第一日 TOP10精彩集锦
2015/01/30 DOTA
python算法学习之计数排序实例
2013/12/18 Python
pycharm 将python文件打包为exe格式的方法
2019/01/16 Python
Python使用统计函数绘制简单图形实例代码
2019/05/15 Python
pyqt5与matplotlib的完美结合实例
2019/06/21 Python
Python列表的深复制和浅复制示例详解
2021/02/12 Python
HTML5中语义化 b 和 i 标签
2008/10/17 HTML / CSS
优衣库英国官网:UNIQLO英国
2016/12/25 全球购物
前厅部经理岗位职责范文
2014/02/04 职场文书
新闻学专业大学生职业生涯规划范文
2014/03/02 职场文书
中药学专业毕业生推荐信
2014/07/10 职场文书
支部书记四风问题自我剖析材料
2014/09/29 职场文书
婚育证明格式
2015/06/17 职场文书
MySQL数据库 任意ip连接方法
2022/05/20 MySQL
JS前端canvas交互实现拖拽旋转及缩放示例
2022/08/05 Javascript