js 正则收集

验证汉字

function isName (str){
    var reg =  /^[\u4e00-\u9fa5]+$/;
    return reg.test(str);
}

验证电话号

function isPhoneNum(str){
    var reg = /^1[3|4|5|7|8][0-9]{9}$/;
    return reg.test(str);
}   

验证身份证号

function IdentityCodeValid(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(idCard.length == 0 || idCard == null || idCard == 'undefined') {
    alert("身份证号码为空!");
    return false;
  } else 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(var i = 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") {
          //alert("1恭喜通过验证啦!");
          return true;
        } else {
          alert("身份证号码错误!");
          return false;
        }
      } else {
        //用计算出的验证码与最后一位身份证号码匹配,如果一致,说明通过,否则是无效的身份证号码
        if(idCardLast == idCardY[idCardMod]) {
          //alert("2恭喜通过验证啦!");
          return true;
        } else {
          alert("身份证号码错误!");
          return false;
        }
      }
    }
  } else {
    alert("身份证格式不正确!");
    return false;
  }
}

去除空格

function removeAllSpace(str) {
   return str.replace(/\s+/g, "");
}

更多
还有

你可能感兴趣的:(js 正则收集)