javascript实现检验的各种规则


Posted in Javascript onJuly 31, 2015

本文实例讲述了javascript实现检验的各种规则。分享给大家供大家参考。具体如下:

/**
 * 检验各种规则
 * @param str 检验的内容
 * @param cType 预设的检验规则 字符串[
 *       empty,  检验是否为空
 *       telphone, 座机手机号码
 *       allphone, 所有手机号码
 *       ydphone, 移动手机号码
 *       ltphone, 联通手机号码
 *       dxphone, 电信手机号码
 *       email,  邮箱
 *       url,  网址
 *       cn,   汉字
 *       image,  图片格式
 *       emscode, 邮政编码
 *       isEmpty, 检查是否为空
 *       isint,  整数
 *       isfloat, 判断是否为正小数
 *       isnumber, 判断为实数
 *       words,  判断是否为英文字母
 *       wordsAndNum,   判断是否为字母+数字
 *       wordsAndNumAndDownline, 判断是否由数字、26个英文字母或者下划线组成的字符串
 *       qq,      QQ检验
 *       personCard18,   身份证18位
 *       personCard15,   身份证15位
 *       ]
 * @param regex 自定义表达式 传入格式例如:"^\-?[1-9]+\d*$"
 *
 * @description cType 与 regex 只能有一个为空
 *    如 checkObjectByRegex("测试中文", "cn"); // 判断中文
 *    如 checkObjectByRegex("测试中文", null, "^[\u4e00-\u9fa5]+$"); // 自定义表达式正则
 * @return {boolean}
 */
function checkObjectByRegex(str, cType, regex) {
 /**
  * 定义验证各种格式类型的正则表达式对象
  */
 var Regexs = {
  telphone: (/^((\(\d{3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}$/), //座机手机号码
  allphone: (/^((13[0-9])|(14[57])|(15[0-9])|(17[678])|(18[0-9]))[0-9]{8}$/),   //所有手机号码
  ydphone: (/^((13[4-9])|(15[012789])|147|178|(18[23478]))[0-9]{8}$/),   //移动手机号码
  ltphone: (/^((13[0-2])|(145)|(15[56])|(176)|(18[56]))[0-9]{8}$/),     //联通手机号码
  dxphone: (/^((133)|(153)|(177)|(180)|(181)|(189))[0-9]{8}$/),    //电信手机号码
  email: (/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((\.[a-zA-Z0-9_-]{2,3}){1,2})$/),//邮箱
  url: (/(?:https|http|ftp|rtsp|mms):\/\/.+\/[\w]+\.[\w]+/),     //网址
  cn: (/^[\u4e00-\u9fa5]+$/i), //汉字
  image: (/\.jpg$|\.jpeg$|\.png$/i), //图片格式
  emscode: (/^[1-9]\d{5}$/), //邮政编码
  isint: (/^(\-)?[1-9]+\d*$/), //整数
  isfloat: (/^[0-9]+\.?[0-9]*$/), //判断是否为正小数
  isnumber: (/^[-\+]?\d+(\.\d+)?$/), //判断为实数
  words: (/^[A-Za-z]+$/), //判断是否为英文字母
  wordsAndNum: (/^[A-Za-z0-9]+$/), //判断是否为字母+数字
  wordsAndNumAndDownline: (/^\w+$/), //判断是否由数字、26个英文字母或者下划线组成的字符串
  qq: (/^[1-9]\d{4,11}$/), //QQ
  personCard18: (/^(\d{6})()?(\d{4})(\d{2})(\d{2})(\d{3})(\d|X)$/), //身份证18位
  personCard15: (/^(\d{6})()?(\d{2})(\d{2})(\d{2})(\d{3})$/) //身份证15位
 };
 var nReg;
 if (str == null || typeof(str) == "undefined") {
  str = "";
 }
 if (cType != null && typeof(cType) != "undefined") {
  if (cType == "isEmpty") {
   str = $.trim(str);
   if (str != null && typeof(str) != "undefined" && str != "") {
    return false;
   } else return true;
  }
  nReg = Regexs[cType];
  if (str == null || str == "") return false; //输入为空,认为是验证通过
  // 针对 18位身份证单独处理
  if (cType == 'personCard18') {
   var ary = str.match(Regexs[cType]);
   if (!(parseInt(ary[3]) >= 1900)) return false;
   var D = new Date(ary[3] + "/" + ary[4] + "/" + ary[5]);
   var isTrue = D.getFullYear() == ary[3] && (D.getMonth() + 1) == ary[4] && D.getDate() == ary[5];
   return isTrue;
  }
  // 针对 15位身份证单独处理
  if (cType == 'personCard15') {
   var ary = str.match(Regexs[cType]);
   var D = new Date("19" + ary[3] + "/" + ary[4] + "/" + ary[5]);
   var isTrue = D.getYear() == ary[3] && (D.getMonth() + 1) == ary[4] && D.getDate() == ary[5];
   return isTrue;
  }
 } else {
  // 自定义正则表达式处理
  if (regex != null && typeof(regex) != "undefined") {
   nReg = new RegExp(regex);
  } else {
   return false;
  }
 }
 return nReg.test(str);
}

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
几个javascript操作word的参考代码
Oct 26 Javascript
JavaScript 开发规范要求(图文并茂)
Jun 11 Javascript
js怎么终止程序return不行换jfslk
May 30 Javascript
js判断ie版本号的简单实现代码
Mar 05 Javascript
jQuery中each()方法用法实例
Dec 27 Javascript
微信小程序 SocketIO 实例讲解
Oct 13 Javascript
详解从angular-cli:1.0.0-beta.28.3升级到@angular/cli:1.0.0
May 22 Javascript
JavaScript输入分钟、秒倒计时技巧总结(附代码)
Aug 17 Javascript
JavaScript实现单例模式实例分享
Dec 22 Javascript
解决vue.js this.$router.push无效的问题
Sep 03 Javascript
vue+koa2实现session、token登陆状态验证的示例
Aug 30 Javascript
15分钟上手vue3.0(小结)
May 20 Javascript
纯JS实现本地图片预览的方法
Jul 31 #Javascript
javascript动画算法实例分析
Jul 31 #Javascript
jquery实现手机号码选号的方法
Jul 31 #Javascript
javascript文本模板用法实例
Jul 31 #Javascript
Javascript实现网络监测的方法
Jul 31 #Javascript
jquery模拟alert的弹窗插件
Jul 31 #Javascript
JSON字符串转JSON对象
Jul 31 #Javascript
You might like
坏狼的PHP学习教程之第2天
2008/06/15 PHP
php实现高效获取图片尺寸的方法
2014/12/12 PHP
PHP加密解密字符串汇总
2015/04/26 PHP
浅谈Yii乐观锁的使用及原理
2017/07/25 PHP
基于Laravel(5.4版本)的基本增删改查操作方法
2019/10/11 PHP
解析John Resig Simple JavaScript Inheritance代码
2012/12/03 Javascript
javascript中的__defineGetter__和__defineSetter__介绍
2014/08/15 Javascript
jQuery表单域选择器用法分析
2015/02/10 Javascript
JavaScript中eval()函数用法详解
2015/12/14 Javascript
基于jquery实现表格无刷新分页
2016/01/07 Javascript
多种JQuery循环滚动文字图片效果代码
2020/06/23 Javascript
jQuery回到顶部的代码
2016/07/09 Javascript
Vue.js每天必学之方法与事件处理器
2016/09/06 Javascript
js学习笔记之事件处理模型
2016/10/31 Javascript
JavaScript之json_动力节点Java学院整理
2017/06/29 Javascript
Vue Transition实现类原生组件跳转过渡动画的示例
2017/08/19 Javascript
微信小程序实现的canvas合成图片功能示例
2019/05/03 Javascript
Vue父子组件传值的一些坑
2020/09/16 Javascript
微信小程序实现打卡签到页面
2020/09/21 Javascript
Python 可爱的大小写
2008/09/06 Python
利用Python的Twisted框架实现webshell密码扫描器的教程
2015/04/16 Python
详解Python中表达式i += x与i = i + x是否等价
2017/02/08 Python
python中copy()与deepcopy()的区别小结
2018/08/03 Python
对python pandas读取剪贴板内容的方法详解
2019/01/24 Python
python pytest进阶之xunit fixture详解
2019/06/27 Python
python实现集中式的病毒扫描功能详解
2019/07/09 Python
python编写softmax函数、交叉熵函数实例
2020/06/11 Python
介绍一下grep命令的使用
2015/06/12 面试题
学习经验演讲稿
2014/05/10 职场文书
升职演讲稿范文
2014/05/23 职场文书
民主生活会剖析材料
2014/09/30 职场文书
代收款委托书范本
2014/10/01 职场文书
2014年教学管理工作总结
2014/12/02 职场文书
工厂清洁工岗位职责
2015/02/14 职场文书
评奖评优个人先进事迹材料
2015/11/04 职场文书
Python Parser的用法
2021/05/12 Python