标签:under UNC 冗余 因子 4行 很多 span str 否则
六位数字地址码 + 八位数字出生日期码 + 三位数字顺序码 + 一位数字校验码
checkIdCard: function (idCard){ //15位和18位身份证号码的正则表达式 var regIdCard=/^(^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$)|(^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])((\d{4})|\d{3}[Xx])$)$/; //如果通过该验证,说明身份证格式正确,但准确性还需计算 if(regIdCard.test(idCard)){ if(idCard.length==18){ var idCardWi=new Array(7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2);//将前17位加权因子保存在数组里 var idCardY=new Array(1,0,10,9,8,7,6,5,4,3,2);//这是除以11后,可能产生的11位余数、验证码,也保存成数组 var idCardWiSum=0;//用来保存前17位各自乖以加权因子后的总和 for(vari=0;i<17;i++){ idCardWiSum+=idCard.substring(i,i+1)*idCardWi[i]; } var idCardMod=idCardWiSum%11;//计算出校验码所在数组的位置 var idCardLast=idCard.substring(17);//得到最后一位身份证号码 //如果等于2,则说明校验码是10,身份证号码最后一位应该是X if(idCardMod==2){ if(idCardLast=="X"||idCardLast=="x"){ return true; }else{ return false; } }else{ //用计算出的验证码与最后一位身份证号码匹配,如果一致,说明通过,否则是无效的身份证号码 if(idCardLast==idCardY[idCardMod]){ return true; }else{ return false; } } } }else{ return false; } }
看到网上有很多朋友用正则和字符串判断码了过百行代码,实在不适合只在单个文件中应用的场景,只有这段代码简练且精确,适合不封装直接使用。
贴一下原文连接:JS完美校验身份证号有效性函数(亲测)
标签:under UNC 冗余 因子 4行 很多 span str 否则
原文地址:https://www.cnblogs.com/97z4moon/p/14930917.html