js计算字符串长度、汉字校验、去除空格、数字校验、身份证校验的方法

简介:

//计算字符串长度,汉字计两位。
function strLen(str){
   var len = 0;   
   for(i=0;i<str.length;i++)   
   {   
    if(str.charCodeAt(i)>256)   
    {   
     len += 2;   
    }   
    else   
    {   
     len++;   
    }   
   }   
   return len;
}

    //汉字校验
    function isChinese(str)
    {
      var reg=/^[\u4e00-\u9fa5]+$/i;
     if(reg.test(str))
     {//中文校验成功
         return true;
     }else
     {
     return false;
     }
    }

//字符串去除空格等
function trim(str) {   
    return str.replace(/(^\s*)|(\s*$)/g, "");   
}


//数字校验
function   isNum(str){ 
   var   reg=/^[0-9]*[1-9][0-9]*$/;   
   if(reg.test(str)   ==   false) 
   {
      return   false; 
   } 
   return true;
}

//数字校验,可以有小数点如11.0
function   isNum(str){
alert(4);
//var   reg=/^[0-9]*[1-9][0-9]*$/;   
var reg= /^\d+(?=\.{0,1}\d+$|$)/ ;

if(reg.test(str) == false) 
{
return   false; 

return true; 
}

//比较弱的身份证校验,只校验长度是否为15或18位
function checkIdcard1(idcard1){
var idcard=this.trim(idcard1);

/*必填校验*/ 
   if(idcard == "" || idcard == null || idcard.length == 0)    
   {
   document.getElementById("validatorTextForText2").innerHTML = "身份证号为空,请输入您的身份证号!";
   return false;   
   } 
   
   if( idcard.length ==15 || idcard.length == 18){
      return true;
   }else{
      //长度不匹配
      document.getElementById("validatorTextForText2").innerHTML = "身份证号码位数不对!";
      return false;   
   }

}

//非常严格的身份证验证   
function checkIdcard(idcard1){   
   var idcard=this.trim(idcard1);// 对身份证号码做处理。去除头尾空格。
      
   var Errors=new Array(   
   "验证通过!",   
   "身份证号码位数不对!",   
   "身份证号码出生日期超出范围或含有非法字符!",   
   "身份证号码校验错误!",   
   "身份证地区非法!" 
   );   
   var area={11:"北京",12:"天津",13:"河北",14:"山西",15:"内蒙古",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:"国 外"}    
      
   var Y,JYM;   
   var S,M;   
   var idcard_array = new Array();   
   idcard_array = idcard.split(""); 
   /*基本校验*/ 
   if(idcard == "" || idcard == null || idcard.length == 0)    
   {
   document.getElementById("validatorTextForText2").innerHTML = "身份证号为空,请输入您的身份证号!";

   return false;   
   }  

   /*身份号码位数及格式检验*/ 
   switch(idcard.length){   
    case 15:   
    if ( (parseInt(idcard.substr(6,2))+1900) % 4 == 0 || ((parseInt(idcard.substr(6,2))+1900) % 100 == 0 && (parseInt(idcard.substr(6,2))+1900) % 4 == 0 )){   
     ereg=/^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2] [0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9])) [0-9]{3}$/;//测试出生日期的合法性   
    } else {   
     ereg=/^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2] [0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2] [0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}$/;//测试出生日期的合法性   
    }   
    if(ereg.test(idcard)){   
      //alert(Errors[0]+"15");    
      return true; //15位验证通过   
     }   
    else {   
       document.getElementById("validatorTextForText2").innerHTML = Errors[2];

       return false;   
      }   
    break;   
       
    case 18:   
    //18位身份号码检测   
    //出生日期的合法性检查    
    //闰年月日:((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11) (0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))   
    //平年月日:((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11) (0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))   
    if ( parseInt(idcard.substr(6,4)) % 4 == 0 || (parseInt(idcard.substr(6,4)) % 100 == 0 && parseInt(idcard.substr(6,4))%4 == 0 )){   
    ereg=/^[1-9][0-9]{5}19[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2] [0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9])) [0-9]{3}[0-9Xx]$/;//闰年出生日期的合法性正则表达式   
    } else {   
    ereg=/^[1-9][0-9]{5}19[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2] [0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2] [0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}[0-9Xx]$/;//平年出生日期的合法性正则表达式   
    }   
    if(ereg.test(idcard)){//测试出生日期的合法性   
     //计算校验位   
     S = (parseInt(idcard_array[0]) + parseInt(idcard_array[10])) * 7   
     + (parseInt(idcard_array[1]) + parseInt(idcard_array[11])) * 9   
     + (parseInt(idcard_array[2]) + parseInt(idcard_array[12])) * 10   
     + (parseInt(idcard_array[3]) + parseInt(idcard_array[13])) * 5   
     + (parseInt(idcard_array[4]) + parseInt(idcard_array[14])) * 8   
     + (parseInt(idcard_array[5]) + parseInt(idcard_array[15])) * 4   
     + (parseInt(idcard_array[6]) + parseInt(idcard_array[16])) * 2   
     + parseInt(idcard_array[7]) * 1    
     + parseInt(idcard_array[8]) * 6   
     + parseInt(idcard_array[9]) * 3 ;   
     Y = S % 11;   
     alert("y="+Y);
     M = "F";   
     JYM = "10X98765432";   
     M = JYM.substr(Y,1);/*判断校验位*/
     alert("m="+M); 
     alert("idcard_array[17]="+idcard_array[17]);
     if(M == idcard_array[17]){   
      //alert(Errors[0]+"18");    
      return true; /*检测ID的校验位false;*/ 
      
     }   
     else {   
     alert("这是什么问题?");
     document.getElementById("validatorTextForText2").innerHTML = Errors[3];

      return false;   
     }   
    }   
    else {   
    document.getElementById("validatorTextForText2").innerHTML = Errors[2];

     return false;   
    }   
    break;   
       
    default:   
     document.getElementById("validatorTextForText2").innerHTML = Errors[1];

     return false;   
   }   
   
      /*地区检验*/ 
   if(area[parseInt(idcard.substr(0,2))]==null)    
   {
    document.getElementById("validatorTextForText2").innerHTML =Errors[4];
       
    return false;   
   }   else{
   return true;
   }
}



本文转自 斯然在天边 51CTO博客,原文链接:http://blog.51cto.com/winters1224/799076,如需转载请自行联系原作者

相关文章
|
1月前
|
JavaScript 前端开发 程序员
前端原生Js批量修改页面元素属性的2个方法
原生 Js 的 getElementsByClassName 和 querySelectorAll 都能获取批量的页面元素,但是它们之间有些细微的差别,稍不注意,就很容易弄错!
|
1月前
|
监控 JavaScript Java
Node.js中内存泄漏的检测方法
检测内存泄漏需要综合运用多种方法,并结合实际的应用场景和代码特点进行分析。及时发现和解决内存泄漏问题,可以提高应用的稳定性和性能,避免潜在的风险和故障。同时,不断学习和掌握内存管理的知识,也是有效预防内存泄漏的重要途径。
130 52
|
1月前
|
缓存 JavaScript UED
js中BOM中的方法
【10月更文挑战第31天】
|
1月前
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
47 5
|
1月前
|
JavaScript 前端开发 数据处理
模板字符串和普通字符串在浏览器和 Node.js 中的性能表现是否一致?
综上所述,模板字符串和普通字符串在浏览器和 Node.js 中的性能表现既有相似之处,也有不同之处。在实际应用中,需要根据具体的场景和性能需求来选择使用哪种字符串处理方式,以达到最佳的性能和开发效率。
|
1月前
|
JavaScript 前端开发 索引
JavaScript学习第二章--字符串
本文介绍了JavaScript中的字符串处理,包括普通字符串和模板字符串的使用方法及常见字符串操作方法如`charAt`、`concat`、`endsWith`等,适合前端学习者参考。作者是一位热爱前端技术的大一学生,专注于分享实用的编程技巧。
27 2
|
1月前
|
JavaScript 前端开发
js中的bind,call,apply方法的区别以及用法
JavaScript中,`bind`、`call`和`apply`均可改变函数的`this`指向并传递参数。其中,`bind`返回一个新函数,不立即执行;`call`和`apply`则立即执行,且`apply`的参数以数组形式传递。三者在改变`this`指向及传参上功能相似,但在执行时机和参数传递方式上有所区别。
27 1
|
1月前
|
JavaScript 前端开发
.js方法参数argument
【10月更文挑战第26天】`arguments` 对象为JavaScript函数提供了一种灵活处理参数的方式,能够满足各种不同的参数传递和处理需求,在实际开发中具有广泛的应用价值。
45 7
|
1月前
|
JavaScript 前端开发
JavaScript中的原型 保姆级文章一文搞懂
本文详细解析了JavaScript中的原型概念,从构造函数、原型对象、`__proto__`属性、`constructor`属性到原型链,层层递进地解释了JavaScript如何通过原型实现继承机制。适合初学者深入理解JS面向对象编程的核心原理。
27 1
JavaScript中的原型 保姆级文章一文搞懂
|
5月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
107 2