JS实现的表单验证和强大的身份证

news/2024/9/3 0:30:09 标签: JavaScript
/规则检查排序
function RegCheck(objs)
 {
  var str = objs.checktype;
  switch (str)
   {
       case "cn" :    //要检查的表单控件的输入类型必须为中文
          return CnWordRegCheck(objs);
          break;
       case "idnum" :
          return IdCardRegCheck(objs); //要检查的表单控件的输入类型必须为身份证号
          break;
    case "num" :    //要检查的表单控件的输入类型必须为数字
           return NumRegCheck(objs);
     break;
    case "mail" :    //要检查的表单控件的输入类型必须为EMAIL
          return EmailRegCheck(objs);
          break;
    case "txt" :   //要检查的表单控件的输入类型必须为字符串
     return SpecialWordRegCheck(objs);
     break;
    case "notes" :
     return true; //要检查的表单控件的输入类型必须为什么都可以
     break;
   }
 }
//************************************************
//检查电话号码
function NumRegCheck(obj)
 {
  var uplimit = obj.checkrule.split(",")[0];
  var downlimit = obj.checkrule.split(",")[1];
  var reg = "";
  if (downlimit == null)
   {
     reg = eval_r("/^[0-9]{"+uplimit+"}$/");
   }
  else
   {
     reg = eval_r("/^[0-9]{"+uplimit+","+downlimit+"}$/");
   }
  var str = obj.value;
  var flag = reg.test(str);
  return flag;
 }
//************************************************
//检查身份证号
function IdCardRegCheck(obj)
 {
  var str = obj.value;
  var reg = /^([0-9]{15}|[0-9]{18})$/;
  var flag = reg.test(str);
  return flag;
 }
//************************************************
//检查EMAIL
function EmailRegCheck(obj)
 {
  var str = obj.value;
  var reg = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((\.[a-zA-Z0-9_-]{2,3}){1,2})$/;
  var flag = reg.test(str);
  return flag;
 }
//***************************************
//检查中文输入
function CnWordRegCheck(obj)
 {
  var str = obj.value;
  var reg=/^[\u4e00-\u9fa5](\s*[\u4e00-\u9fa5])*$/;
  var flag = reg.test(str);
  //alert(flag);
  return flag;
 }
//***************************************
//检查特殊字符
function SpecialWordRegCheck(obj)
 {
  var reg= /[(\/)(<)(>)]/g">\\)(')(")(<)(>)]/g;
  var str = obj.value;
  var flag= reg.test(str);
  flag = !flag;
  return flag;
 }
//************************************************
//检查主引导函数
function CheckForm(obj)
 {
  var myform = eval_r("document."+obj.name);
 
  for (i=0;i<myform.elements.length;i++)
   {
    var formvalue = myform.elements[i].value;
    //内容非空检查,长度检查
    if ((myform.elements[i].value == "")||(myform.elements[i].value.length>myform.elements[i].maxlength))
     {
      alert("您忘了填写"+myform.elements[i].cnname+"!"+"或者您填写的信息不符合规范!");
      myform.elements[i].focus();
      return false;
      break;
     }
 
     if (myform.elements[i].value == 0)
     {
      alert("您忘了选择"+myform.elements[i].cnname+"!");
      myform.elements[i].focus();
      return false;
      break;
     }
    //数据规范化检查
    var myobj = myform.elements[i];
    //alert(myobj.checktype);
    //break;
    if (!RegCheck(myobj))
     {
      alert(myobj.cnname+"输入有误,请按填写要求填写!");
        myobj.focus();
      return false;
      break;
     }
   }
 }

 
js身份证号码严格验证
<script>
function checkIdcard(idcard){
var Errors=new Array(
"验证通过!",
"身份证号码位数不对!",
"身份证号码出生日期超出范围或含有非法字符!",
"身份证号码校验错误!",
"身份证地区非法!"
);
var area={11:"北京",12:"天津",13:"河北",14:"山西",15:"内蒙古",21:"辽宁",22:"吉林",23:"黑龙江",31:"上海",32:"江苏",33:"浙江",34:"安徽",35:"福建",36:"江西",37:"山东",41:"河南",42:"湖北",43:"湖南",44:"广东",45:"广西",46:"海南",50:"重庆",51:"四川",52:"贵州",53:"云南",54:"西藏",61:"陕西",62:"甘肃",63:"青海",64:"宁夏",65:"新疆",71:"台湾",81:"香港",82:"澳门",91:"国外"}

 

var idcard,Y,JYM;
var S,M;
var idcard_array = new Array();
idcard_array = idcard.split("");
//地区检验
if(area[parseInt(idcard.substr(0,2))]==null) return Errors[4];
//身份号码位数及格式检验
switch(idcard.length){
case 15:
if ( (parseInt(idcard.substr(6,2))+1900) % 4 == 0 || ((parseInt(idcard.substr(6,2))+1900) % 100 == 0 && (parseInt(idcard.substr(6,2))+1900) % 4 == 0 )){
ereg=/^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}$/;//测试出生日期的合法性
} else {
ereg=/^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}$/;//测试出生日期的合法性
}
if(ereg.test(idcard)) return Errors[0];
else return Errors[2];
break;
case 18:
//18位身份号码检测
//出生日期的合法性检查
//闰年月日:((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))
//平年月日:((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))
if ( parseInt(idcard.substr(6,4)) % 4 == 0 || (parseInt(idcard.substr(6,4)) % 100 == 0 && parseInt(idcard.substr(6,4))%4 == 0 )){
ereg=/^[1-9][0-9]{5}19[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}[0-9Xx]$/;//闰年出生日期的合法性正则表达式
} else {
ereg=/^[1-9][0-9]{5}19[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}[0-9Xx]$/;//平年出生日期的合法性正则表达式
}
if(ereg.test(idcard)){//测试出生日期的合法性
//计算校验位
S = (parseInt(idcard_array[0]) + parseInt(idcard_array[10])) * 7
+ (parseInt(idcard_array[1]) + parseInt(idcard_array[11])) * 9
+ (parseInt(idcard_array[2]) + parseInt(idcard_array[12])) * 10
+ (parseInt(idcard_array[3]) + parseInt(idcard_array[13])) * 5
+ (parseInt(idcard_array[4]) + parseInt(idcard_array[14])) * 8
+ (parseInt(idcard_array[5]) + parseInt(idcard_array[15])) * 4
+ (parseInt(idcard_array[6]) + parseInt(idcard_array[16])) * 2
+ parseInt(idcard_array[7]) * 1
+ parseInt(idcard_array[8]) * 6
+ parseInt(idcard_array[9]) * 3 ;
Y = S % 11;
M = "F";
JYM = "10X98765432";
M = JYM.substr(Y,1);//判断校验位
if(M == idcard_array[17]) return Errors[0]; //检测ID的校验位
else return Errors[3];
}
else return Errors[2];
break;
default:
return Errors[1];
break;
}

}
alert(checkIdcard("220183198808081610"))
</script>


http://www.niftyadmin.cn/n/580759.html

相关文章

iOS实现包含100万条数据的视图顺滑滚动和闪电跳转到任意数据对应的页面

功能需求 在iOS里,无论是用UIKit还是SwiftUI,显示一个包含100w条数据的视图都必定会出现难以忍受的卡顿,更别提滚动它的内容了。 如上所示,视图中包含了100万条数据(每页5条数据),滚动或跳转到其中任意页面却没有丝毫卡顿。 这在UIKit和SwiftUI中是如何实现的呢? 在本…

grid中显示blobImage上传的图片 通过本案例,我们实现blobImage上传的图片在grid表格中的显示。 grid的cellRender方法渲染单元格显示图片,例: 1 2 3 4 5

在JavaScript中, “this”是一个关键字&#xff0c;它在不同的环境下&#xff0c;代表的含义不同&#xff0c;关于“this”的详细解释&#xff0c;可以参考“深入浅出 JavaScript 中的 this”。下面将介绍在WeX5中&#xff0c;在不同的场景下“this”的使用。 1234567891011121…

C#有关时间处理的一些方法,两个日期间相差的天、小时、分钟、月数等

//取得某月的最后一天 //方法一&#xff1a;使用算出該月多少天&#xff0c;年月加上多少天即得&#xff0c;舉例取今天這個月的最后一天 private void GetLastDateForMonth(DateTime DtStart, out DateTime DtEnd) { int Dtyear, DtMonth; DtStart Da…

Xcode13模拟器和预览(Preview)导致Mac处理器占用率急剧飙升的解决方法

问题现象 在升级到Xcode13后,不少小伙伴们会发现运行模拟器会导致CPU占用率一直居高不下。不仅如此,在Xcode中切换至预览界面也会非常的卡顿。 这是什么原因导致又该如何解决呢? 别急,让我们就在本篇博文中一探究竟吧!😉 问题分析 在将Xcode升级到13之后,在两种情况…

6个类似书本翻页效果的jQuery插件

Turn.js turn.js 是一款用来实现纸制书翻页的 jQuery 插件。使用硬件加速&#xff0c;跨平台&#xff0c;容易维护&#xff0c;体积小&#xff08;不到 15K&#xff09;。基于 HTML5 和 jQuery 实现。Turn.js 支持硬件加速来让翻页效果更加平滑。 可通过 API 来获取当前显示的…

iOS14中点击SwiftUI列表项导航跳转返回后外观呈灰色的解决

问题现象 在iOS 14.0系统中(iOS 15中已修复),若List项可导航,则点击跳转到目的视图再返回父视图后,原列表项外观会变成灰色: 虽然不影响使用,但让强迫症的我们怎能忍受呢? 想知道如何解决吗? 答案超乎寻常的简单!Let’s Go! 问题分析 1. 有问题的代码 下面,让我先…

JavaScript DOM的本质及操作方法

虽然现在一些JavaScript框架&#xff0c;诸如jQuery、Prototype和MooTools能提高我们的前端开发效率&#xff0c;而且很好的解决了浏览器兼容性问题&#xff0c;但我们仍要打好javascript技术基础。文章将介绍JavaScript和文档对象模型(DOM)的本质。 JavsScript是可以在各种不同…

Android模拟器大小

一&#xff1a;Android模拟器大小分类1&#xff09;320480, portrait : emulator -skin HVGA-P (default)2&#xff09;320240, landscape: emulator -skin QVGA-L3&#xff09;480320, landscape: emulator -skin HVGA-L4&#xff09;240320, portrait : emulator -skin QVGA-…