欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

jQuery使用正則驗證15/18身份證的方法示例

 更新時間:2017年04月27日 11:21:58   作者:websites  
這篇文章主要介紹了jQuery使用正則驗證15/18身份證的方法,涉及jQuery基于正則進行數(shù)字字符串驗證相關操作技巧,需要的朋友可以參考下

本文實例講述了jQuery使用正則驗證15/18身份證的方法。分享給大家供大家參考,具體如下:

最好的jQuery正則驗證身份證代碼:

按照身份證的算法定制而成,精確度完美支持15和18位. 錯一個數(shù)字或字母都通不過,無需通過數(shù)據(jù)處理來驗證

//身份證檢驗
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ù)字,最后一位是校驗位,可能為數(shù)字或字符X
  var reg = /(^\d{15}$)|(^\d{17}(\d|X)$)/;
  if(reg.test(card) === false){
    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位)年(2位)月(2位)日(2位)校驗位(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位時,次序為?。?位)市(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;
};
if (!checkCard(code)) {
  alert("請輸入正確的身份證號碼");
  return false;
}

PS:這里再為大家提供2款非常方便的正則表達式工具供大家參考使用:

JavaScript正則表達式在線測試工具:
http://tools.jb51.net/regex/javascript

正則表達式在線生成工具:
http://tools.jb51.net/regex/create_reg

更多關于jQuery相關內(nèi)容可查看本站專題:《jQuery正則表達式用法總結》、《jQuery字符串操作技巧總結》、《jQuery操作xml技巧總結》、《jQuery擴展技巧總結》、《jquery選擇器用法總結》及《jQuery常用插件及用法總結

希望本文所述對大家jQuery程序設計有所幫助。

相關文章

  • 精心挑選的15款優(yōu)秀jQuery 本特效插件和教程

    精心挑選的15款優(yōu)秀jQuery 本特效插件和教程

    今天這篇文章向大家分享15款精心挑選的優(yōu)秀 jQuery 文本特效插件,都帶有詳細的使用教程。jQuery 是最流行和使用最廣泛的 JavaScript 框架,它簡化了 HTML 文檔遍歷,事件處理,動畫以及Ajax交互,幫助 Web 開發(fā)人員更快速的實現(xiàn)各種精美的界面效果
    2012-08-08
  • jQuery中get和post方法傳值測試及注意事項

    jQuery中get和post方法傳值測試及注意事項

    jQuery 的 get 和 post 方法有三個參數(shù):地址,數(shù)據(jù) 和回調(diào)函數(shù),剛剛做了幾個實驗,看看下面的代碼就清楚了
    2014-08-08
  • jQuery簡單tab切換效果實現(xiàn)方法

    jQuery簡單tab切換效果實現(xiàn)方法

    這篇文章主要介紹了jQuery簡單tab切換效果實現(xiàn)方法,涉及jQuery鏈式操作及遍歷的技巧,是非常具有實用價值的功能,需要的朋友可以參考下
    2015-04-04
  • jQuery 判斷頁面元素是否存在的代碼

    jQuery 判斷頁面元素是否存在的代碼

    在傳統(tǒng)的Javascript里,當我們對某個頁面元素進行某種操作前,最好先判斷這個元素是否存在。原因是對一個不存在的元素進行操作是不允許的。
    2009-08-08
  • jQuery中的deferred使用方法

    jQuery中的deferred使用方法

    deferred對象是jQuery的回調(diào)函數(shù)解決方案,jQuery之前的版本中異步回調(diào)這塊做的不是很好,所以后期補上了該解決方案。接下來通過本文給大家介紹jQuery中的derferred使用方法,非常不錯,需要的朋友參考下
    2017-03-03
  • jQuery實現(xiàn)的監(jiān)聽導航滾動置頂狀態(tài)功能示例

    jQuery實現(xiàn)的監(jiān)聽導航滾動置頂狀態(tài)功能示例

    這篇文章主要介紹了jQuery實現(xiàn)的監(jiān)聽導航滾動置頂狀態(tài)功能,涉及基于jQuery的事件響應及狀態(tài)監(jiān)聽等相關操作技巧,需要的朋友可以參考下
    2018-07-07
  • jQuery技巧總結

    jQuery技巧總結

    隨著WEB2.0及ajax思想在互聯(lián)網(wǎng)上的快速發(fā)展傳播,陸續(xù)出現(xiàn)了一些優(yōu)秀的Js框架,其中比較著名的有Prototype、YUI、jQuery、mootools、Bindows以及國內(nèi)的JSVM框架等
    2011-01-01
  • jquery.post用法關于type設置問題補充

    jquery.post用法關于type設置問題補充

    當使用ajax獲取data數(shù)據(jù)的時候,直接data.foo就可以得到。而較低版本的jquery就不行比如1.4之前,下面為大家介紹下jquery.post用法關于type設置問題
    2014-01-01
  • jQuery點擊自身以外地方關閉彈出層的簡單實例

    jQuery點擊自身以外地方關閉彈出層的簡單實例

    本篇文章主要是對jQuery點擊自身以外地方關閉彈出層的簡單實例進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2013-12-12
  • jquery中動態(tài)效果小結

    jquery中動態(tài)效果小結

    只需引入jqery.js,不需要引入插件,利用jquery定義的一些基本方法,就能實現(xiàn)諸如隱藏,顯示,淡入,淡出,半透明等
    2010-12-12

最新評論