概述
javascript实现验证身份证号的有效性并提示
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实现验证身份证号的有效性并提示的全部内容,希望文章能够帮你解决javascript实现验证身份证号的有效性并提示所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复