|
|
|
|
|
身份證合法性校驗(yàn)的JavsScript實(shí)例代碼,主要運(yùn)用了正則表達(dá)式,來校驗(yàn)輸入號(hào)碼是否符合身份證號(hào)碼編碼規(guī)則。
編碼規(guī)則如下:
身份證號(hào)碼編碼規(guī)則
下面是完整的HTML代碼
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width" />
<title>IdCard</title>
<script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
</head>
<body style="text-align:center;">
<p>身份證號(hào):
<input type="text" id="idcard" style="width:200px"/>
<input type="button" id="checkidcard" value="校驗(yàn)身份" /></p>
<p>校驗(yàn)結(jié)果:
<input type="text" id="istrue" style="width:275px"/></p>
<script>
$(function () {
$("#checkidcard").click(function () {
if (isCardNo($("#idcard").val()) == true) {
$("#istrue").val("校驗(yàn)通過");
} else {
$("#istrue").val("校驗(yàn)不通過");
}
});
});
function isCardNo(code) {
var city = { 11: "北京", 12: "天津", 13: "河北", 14: "山西", 15: "內(nèi)蒙古", 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: "臺(tái)灣", 81: "香港", 82: "澳門", 91: "國外 " };
var pass = true;
if (code.length > 0 && !(/^[1-9]\d{5}(19|20|([23]\d))\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$/.test(code) || /^[1-9]\d{5}\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{2}[0-9Xx]$/.test(code))) {
pass = false;
} else if (code.length > 0 && !city[code.substr(0, 2)]) {
pass = false;
} else {
if (code.length == 18) {
code = code.split('');
//∑(ai×Wi)(mod 11)
//加權(quán)因子
var factor = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2];
//校驗(yàn)位
var parity = [1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2];
var sum = 0;
var ai = 0;
var wi = 0;
for (var i = 0; i < 17; i++) {
ai = code[i];
wi = factor[i];
sum += ai * wi;
}
var last = parity[sum % 11];
if (parity[sum % 11] != code[17]) {
pass = false;
}
}
}
return pass;
}
</script>
</body>
</html>
代碼解釋:
1、HTML代碼要先引用jQuery文件
<script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
2、正則表達(dá)式主要使用了test()方法
test()
方法用于檢測一個(gè)字符串是否匹配某個(gè)模式。
語法:
RegExpObject.test(string)
string 必需,這是要檢測的字符串。
返回值:
如果字符串 string 中含有與 RegExpObject 匹配的文本,則返回 true,否則返回 false。
實(shí)例
在下面的例子中,我們將檢索 "WebKaka":
<script type="text/javascript">
var str = "Visit WebKaka";
var patt1 = new RegExp("WebKaka");
var result = patt1.test(str);
document.write("Result: " + result);
</script>
輸出
Result: true