js验证身份证号有效性并提示对应信息

直接上代码,逐行对代码进行研究,一定会有所收获。

function nunber(allowancePersonValue){
 if(allowancePersonValue=="身份证号"){
 $("#span_username").show();
 $("#span_username").html("身份证号不能为空");
 return false;
 }
 //校验长度,类型
 else if(isCardNo(allowancePersonValue) === false)
 {
$("#span_username").show();
 $("#span_username").html("您输入的身份证号码不正确,请重新输入");
 return false;
 }
 //检查省份
 else if(checkProvince(allowancePersonValue) === false)
 {
 $("#span_username").show();
 $("#span_username").html("您输入的身份证号码不正确,请重新输入");
 return false;
 }
 //校验生日
 else if(checkBirthday(allowancePersonValue) === false)
 {
 $("#span_username").show();
 $("#span_username").html("您输入的身份证号码生日不正确,请重新输入");
 return false;
 }
 //检验位的检测
 else if(checkParity(allowancePersonValue) === false)
 {
 $("#span_username").show();
 $("#span_username").html("您的身份证校验位不正确,请重新输入");
 return false;
 }else{
 $("#span_username").hide();
 return true;
 } 

} 

//身份证省的编码
var vcity={ 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:"国外"
    }; 

//检查号码是否符合规范,包括长度,类型
function isCardNo(card){
 //身份证号码为15位或者18位,15位时全为数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X
 var reg = /(^\d{15}$)|(^\d{17}(\d|X)$)/;
 if(reg.test(card) === false){
 //alert("demo");
 return false;
 }
 return true;
} 

//取身份证前两位,校验省份
function checkProvince(card){
 var province = card.substr(0,2);
 if(vcity[province] == undefined){
 return false;
 }
 return true;
} 

//检查生日是否正确
function checkBirthday(card){
 var len = card.length;
 //身份证15位时,次序为省(3位)市(3位)年(2位)月(2位)日(2位)校验位(3位),皆为数字
 if(len == '15'){
   var re_fifteen = /^(\d{6})(\d{2})(\d{2})(\d{2})(\d{3})$/;
   var arr_data = card.match(re_fifteen);
   var year = arr_data[2];
   var month = arr_data[3];
   var day = arr_data[4];
   var birthday = new Date('19'+year+'/'+month+'/'+day);
   return verifyBirthday('19'+year,month,day,birthday);
 }
 //身份证18位时,次序为省(3位)市(3位)年(4位)月(2位)日(2位)校验位(4位),校验位末尾可能为X
 if(len == '18'){
   var re_eighteen = /^(\d{6})(\d{4})(\d{2})(\d{2})(\d{3})([0-9]|X)$/;
   var arr_data = card.match(re_eighteen);
   var year = arr_data[2];
   var month = arr_data[3];
   var day = arr_data[4];
   var birthday = new Date(year+'/'+month+'/'+day);
   return verifyBirthday(year,month,day,birthday);
 }
 return false;
} 

//校验日期
function verifyBirthday(year,month,day,birthday){
 var now = new Date();
 var now_year = now.getFullYear();
 //年月日是否合理
 if(birthday.getFullYear() == year && (birthday.getMonth() + 1) == month && birthday.getDate() == day)
 {
   //判断年份的范围(3岁到100岁之间)
   var time = now_year - year;
   if(time >= 3 && time <= 100)
   {
     return true;
   }
   return false;
 }
 return false;
} 

//校验位的检测
function checkParity(card){
 //15位转18位
 card = changeFivteenToEighteen(card);
 var len = card.length;
 if(len == '18'){
   var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
   var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
   var cardTemp = 0, i, valnum;
   for(i = 0; i < 17; i ++)
   {
     cardTemp += card.substr(i, 1) * arrInt[i];
   }
   valnum = arrCh[cardTemp % 11];
   if (valnum == card.substr(17, 1))
   {
     return true;
   }
   return false;
 }
 return false;
} 

//15位转18位身份证号
function changeFivteenToEighteen(card){
 if(card.length == '15')
 {
   var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
   var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
   var cardTemp = 0, i;
   card = card.substr(0, 6) + '19' + card.substr(6, card.length - 6);
   for(i = 0; i < 17; i ++)
   {
     cardTemp += card.substr(i, 1) * arrInt[i];
   }
   card += arrCh[cardTemp % 11];
   return card;
 }
 return card;
} 

使用方法:

<input type="text" class="reg_txt" value="身份证号" titles="请输入您的身份证号!" name="userid" id="username" maxlength="40" onfocus="if(this.value=='身份证号'){this.value='';}" onblur="if(this.value==''){this.value='身份证号';}nunber(this.value);" style="border: 1px solid red;"><br>
<span class="c_red" id="span_username"></span> 

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

(0)

相关推荐

  • JS验证身份证有效性示例

    复制代码 代码如下: function checkIdcard(idcard){ var Errors=new Array( "验证通过", "身份证号码位数不对!", "身份证号码出生日期超出范围或含有非法字符!", "身份证号码校验错误!", "身份证地区非法!" ); var area={11:"北京",12:"天津",13:"河北",14:

  • JS 正则 时间验证

    复制代码 代码如下: function CheckTime() { var checkValue = new RegExp ("^\[0-2]{1}\[0-6]{1}:\[0-5]{1}\[0-9]{1}:\[0-5]{1}\[0-9]{1}") ; var stControl = document.getElementById("txtStartTime") ; var stValue = stControl.value ; if (stValue == &quo

  • js 验证身份证信息有效性

    以下是根据身份证号码编码规则,使用JS对其进行有效性验证代码 IdCard-Validate.js代码如下: 复制代码 代码如下: /** * 身份证15位编码规则:dddddd yymmdd xx p * dddddd:地区码 * yymmdd: 出生年月日 * xx: 顺序类编码,无法确定 * p: 性别,奇数为男,偶数为女 * <p /> * 身份证18位编码规则:dddddd yyyymmdd xxx y * dddddd:地区码 * yyyymmdd: 出生年月日 * xxx:顺序类

  • JS验证日期的格式YYYY-mm-dd 具体实现

    复制代码 代码如下: function checkInputDate(obj){   var   strDate=obj.value;    var  re =/^(\d{4})-(\d{2})-(\d{2})$/;    if(re.test(strDate))//判断日期格式符合YYYY-MM-DD标准    {     var   dateElement=new   Date(RegExp.$1,parseInt(RegExp.$2,10)-1,RegExp.$3);      if(!(

  • cookie.js 加载顺序问题怎么才有效

    今天遇到一个问题,在使用cookie.js时,只有在jquery.js文件后加载整体才有效 有效加载顺序 复制代码 代码如下: <head> <script type="text/javascript" src="./Scripts/scripts/jquery.1.3.2.js"></script> <script type="text/javascript" src="./Scripts/j

  • js判断日期时间有效性的方法

    分享两种使用javascript验证日期以及时间是否有效的方法 第一种: //| 日期有效性验证 //| 格式为:YYYY-MM-DD或YYYY/MM/DD function IsValidDate(DateStr){ var sDate=DateStr.replace(/(^\s+|\s+$)/g,'');//去两边空格; if(sDate==''){ return true; } //如果格式满足YYYY-(/)MM-(/)DD或YYYY-(/)M-(/)DD或YYYY-(/)M-(/)D或

  • js验证IP及子网掩码的合法性有效性示例

    复制代码 代码如下: function checkIP(ip) { obj=ip; var exp=/^(\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])$/; var reg = obj.match(exp); if(reg==null) { return false;//不合法

  • js判断url是否有效的两种方法

    方法一:(仅适用于ie) 复制代码 代码如下: function CheckStatus(url)        {            XMLHTTP = new ActiveXObject("Microsoft.XMLHTTP")            XMLHTTP.open("HEAD",url,false)            XMLHTTP.send()            return XMLHTTP.status==200        } f

  • js有效数字 显示指定位数

    无标题页 var a = 0.123456789; document.write(a.toPrecision(3)); [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]

  • JSP加载JS文件不起作用的有效解决方法

    目录结构:jsp导入jquery文件,老是不起作用,原因在于: 复制代码 代码如下: <script type="text/javascript" src="js/jquery-1.4.2.min.js"></script> 其不能访问/WEB-INF/目录下的文件,因此需要将加载的js文件其放倒webapp目录.  test.html: 复制代码 代码如下: <%@ page language="java" %&g

  • JS 日期验证正则附asp日期格式化函数

    javascript 日期验证正则 复制代码 代码如下: var pattern = /^((((1[6-9]|[2-9]\d)\d{2})-(0?[13578]|1[02])-(0?[1-9]|[12]\d|3[01]))|(((1[6-9]|[2-9]\d)\d{2})-(0?[13456789]|1[012])-(0?[1-9]|[12]\d|30))|(((1[6-9]|[2-9]\d)\d{2})-0?2-(0?[1-9]|1\d|2[0-8]))|(((1[6-9]|[2-9]\d)

  • js操作Xml(向服务器发送Xml,处理服务器返回的Xml)(IE下有效)

    前台: 复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" > <head> <title>js操作X

  • jQuery在html有效在jsp无效的原因及解决方法

    最近用jQuery来写下拉框的选项值的左右移动,代码如下: 复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <he

随机推荐