jQuery使用正則驗(yàn)證15/18身份證的方法示例
本文實(shí)例講述了jQuery使用正則驗(yàn)證15/18身份證的方法。分享給大家供大家參考,具體如下:
最好的jQuery正則驗(yàn)證身份證代碼:
按照身份證的算法定制而成,精確度完美支持15和18位. 錯一個數(shù)字或字母都通不過,無需通過數(shù)據(jù)處理來驗(yàn)證
//身份證檢驗(yàn) var vcity={ 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:"臺灣",81:"香港",82:"澳門",91:"國外" }; function checkCard(card){ //是否為空 if(!card||!isCardNo(card)||!checkProvince(card)||!checkBirthday(card)||!checkParity(card)){ ZlyJs.divTip("請輸入正確的身份證號碼"); jQuery(".sf_list").focus(); return false; } return true; }; //檢查號碼是否符合規(guī)范,包括長度,類型 function isCardNo(card){ //身份證號碼為15位或者18位,15位時全為數(shù)字,18位前17位為數(shù)字,最后一位是校驗(yàn)位,可能為數(shù)字或字符X var reg = /(^\d{15}$)|(^\d{17}(\d|X)$)/; if(reg.test(card) === false){ return false; } return true; }; //取身份證前兩位,校驗(yàn)省份 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位時,次序?yàn)槭。?位)市(3位)年(2位)月(2位)日(2位)校驗(yàn)位(3位),皆為數(shù)字 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位時,次序?yàn)槭。?位)市(3位)年(4位)月(2位)日(2位)校驗(yàn)位(4位),校驗(yàn)位末尾可能為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; }; //校驗(yàn)日期 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; }; //校驗(yàn)位的檢測 function checkParity(card){ //15位轉(zhuǎn)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位轉(zhuǎn)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; }; if (!checkCard(code)) { alert("請輸入正確的身份證號碼"); return false; }
PS:這里再為大家提供2款非常方便的正則表達(dá)式工具供大家參考使用:
JavaScript正則表達(dá)式在線測試工具:
http://tools.jb51.net/regex/javascript
正則表達(dá)式在線生成工具:
http://tools.jb51.net/regex/create_reg
更多關(guān)于jQuery相關(guān)內(nèi)容可查看本站專題:《jQuery正則表達(dá)式用法總結(jié)》、《jQuery字符串操作技巧總結(jié)》、《jQuery操作xml技巧總結(jié)》、《jQuery擴(kuò)展技巧總結(jié)》、《jquery選擇器用法總結(jié)》及《jQuery常用插件及用法總結(jié)》
希望本文所述對大家jQuery程序設(shè)計有所幫助。
- jquery正則表達(dá)式驗(yàn)證(手機(jī)號、身份證號、中文名稱)
- jquery?validation驗(yàn)證電話號碼,email(實(shí)例代碼)
- jquery插件validation實(shí)現(xiàn)驗(yàn)證身份證號等
- jQuery如何用正則表達(dá)式驗(yàn)證手機(jī)號、身份證號、中文名稱
- jQuery實(shí)現(xiàn)從身份證號中獲取出生日期和性別的方法分析
- jquery 校驗(yàn)中國身份證號碼實(shí)例詳解
- jQuery驗(yàn)證手機(jī)號郵箱身份證的正則表達(dá)式(含港澳臺)
- jquery表單驗(yàn)證框架提供的身份證驗(yàn)證方法(示例代碼)
- jQuery實(shí)現(xiàn)根據(jù)身份證號獲取生日、年齡、性別等信息的方法
相關(guān)文章
精心挑選的15款優(yōu)秀jQuery 本特效插件和教程
今天這篇文章向大家分享15款精心挑選的優(yōu)秀 jQuery 文本特效插件,都帶有詳細(xì)的使用教程。jQuery 是最流行和使用最廣泛的 JavaScript 框架,它簡化了 HTML 文檔遍歷,事件處理,動畫以及Ajax交互,幫助 Web 開發(fā)人員更快速的實(shí)現(xiàn)各種精美的界面效果2012-08-08jQuery中g(shù)et和post方法傳值測試及注意事項(xiàng)
jQuery 的 get 和 post 方法有三個參數(shù):地址,數(shù)據(jù) 和回調(diào)函數(shù),剛剛做了幾個實(shí)驗(yàn),看看下面的代碼就清楚了2014-08-08jQuery簡單tab切換效果實(shí)現(xiàn)方法
這篇文章主要介紹了jQuery簡單tab切換效果實(shí)現(xiàn)方法,涉及jQuery鏈?zhǔn)讲僮骷氨闅v的技巧,是非常具有實(shí)用價值的功能,需要的朋友可以參考下2015-04-04jQuery實(shí)現(xiàn)的監(jiān)聽導(dǎo)航滾動置頂狀態(tài)功能示例
這篇文章主要介紹了jQuery實(shí)現(xiàn)的監(jiān)聽導(dǎo)航滾動置頂狀態(tài)功能,涉及基于jQuery的事件響應(yīng)及狀態(tài)監(jiān)聽等相關(guān)操作技巧,需要的朋友可以參考下2018-07-07jquery.post用法關(guān)于type設(shè)置問題補(bǔ)充
當(dāng)使用ajax獲取data數(shù)據(jù)的時候,直接data.foo就可以得到。而較低版本的jquery就不行比如1.4之前,下面為大家介紹下jquery.post用法關(guān)于type設(shè)置問題2014-01-01jQuery點(diǎn)擊自身以外地方關(guān)閉彈出層的簡單實(shí)例
本篇文章主要是對jQuery點(diǎn)擊自身以外地方關(guān)閉彈出層的簡單實(shí)例進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2013-12-12