常用的js验证和数据处理总结_javascript技巧

前言

在开发web项目的时候,难免遇到各种对网页数据的处理,比如对用户在表单中输入的电话号码、邮箱、金额、身份证号、密码长度和复杂程度等等的验证,以及对后台返回
数据的格式化比如金额,返回的值为null,还有对指定日期之前或之后某一天或某一月的计算。

下面是给大家总结的一些在工作中常用到的js,有需要的可以参考学习。

/**
 * 验证密码复杂度(必须包含数字字母)
 * @param str
 * @returns true:满足规则,false:不满足
 */
function validateStr(str){
  var reg1 = /^(([0-9]{1,})([a-z]{1,}))|(([a-z]{1,})([0-9]{1,}))$/;
  var reg2 = /^(([0-9]{1,})([A-Z]{1,}))|(([A-Z]{1,})([0-9]{1,}))$/;
  //var reg3 = /^([a-zA-Z]{0,})[0-9a-z-A-z]{0,}[~`!@#$%^&*.]{0,}$/;
  str = valueTrim(str);
  //if(reg3.test(str)){
  // return true;
  //}
  if(reg1.test(str)){
    return true;
  }
  if(reg2.test(str)){
    return true;
  }
  return false;
} 

/**
 * 判断字符串长度 必须大于8位小于20位,一般用于密码
 * @param str 字符串
 * @returns 满足返回true
 */
function valiDateLength(str){
  if(str==null || str==''){
    return false;
  }
  str = valueTrim(str);
  if(parseFloat(str.length)<8 ){
    return false;
  }
  if(parseFloat(str.length)>20){
    return false;
  }
  return true;
}
/**
 * 验证时间
 * @param dataValue 格式为:YYYY-MM-DD
 * @returns 匹配返回true 不匹配返回false
 */
function valiDate(dateValue){
  var result = dateValue.match(/((^((1[8-9]\d{2})|([2-9]\d{3}))(-)(10|12|0?[13578])(-)(3[01]|[12][0-9]|0?[1-9])$)|(^((1[8-9]\d{2})|([2-9]\d{3}))(-)(11|0?[469])(-)(30|[12][0-9]|0?[1-9])$)|(^((1[8-9]\d{2})|([2-9]\d{3}))(-)(0?2)(-)(2[0-8]|1[0-9]|0?[1-9])$)|(^([2468][048]00)(-)(0?2)(-)(29)$)|(^([3579][26]00)(-)(0?2)(-)(29)$)|(^([1][89][0][48])(-)(0?2)(-)(29)$)|(^([2-9][0-9][0][48])(-)(0?2)(-)(29)$)|(^([1][89][2468][048])(-)(0?2)(-)(29)$)|(^([2-9][0-9][2468][048])(-)(0?2)(-)(29)$)|(^([1][89][13579][26])(-)(0?2)(-)(29)$)|(^([2-9][0-9][13579][26])(-)(0?2)(-)(29)$))/);
  if(result==null){
    return false;
  }
  return true;
} 

/**
 * 验证电话号码
 * @param phoneValue 要验证的电话号码
 * @returns 匹配返回true 不匹配返回false
 */
function validatePhone(phoneValue) {
  phoneValue = valueTrim(phoneValue);
  var reg = /^[1][0-9]{10}$/;
  return reg.test(phoneValue);
}
/**
 * 验证邮箱
 * @param emailValue 要验证的邮箱
 * @returns 匹配返回true 不匹配返回false
 */
function validateEmail(emailValue){
  var reg = /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/;
  return reg.test(emailValue);
}
/**
 * 判断是否是数字
 * @param numberValue 要验证的数据
 * @returns 匹配返回true 不匹配返回false
 */
function isNumber(numberValue){
  //定义正则表达式部分
  var reg1 = /^[0-9]{0,}$/;
  var reg2 = /^[1-9]{1}[0-9]{0,}$/;
  //alert(numberValue);
  if(numberValue ==null || numberValue.length==0){
    return false;
  }
  numberValue = valueTrim(numberValue);
  //判断当数字只有1位时
  if(numberValue.length<2){
    return reg1.test(numberValue);
  }
  return reg2.test(numberValue);;
}
/***
 * 金额
 * @param value
 * @returns
 */
function isMoney(value) {
  if(value==''){
    return false;
  }
  value = valueTrim(value);
  value = value.replace(/(^\s*)|(\s*$)/g, "");
  var reg = /^[0-9]*\.?[0-9]{0,2}$/;
  if(isNumber(value)){
    return true;
  }
  if(value.length>3){
    if(value.substr(0, 1)=="0"){
      if(value.substr(3,value.length).length>2){
        return false;
      }
    }
  }
  return reg.test(value);
}
/***
 * 判断是否是0到100之间的数
 * @param value
 * @returns
 */
function isZeroToOne(value) {
  if(value==''){
    return false;
  }
  value = valueTrim(value);
  if(isMyFloat(value)){
    if(parseFloat(value)<100 && parseFloat(value)>0){
      return true;
    }
  }
  return false;
} 

/**
 * 验证是否是浮点数
 * @param floatValue 要验证的数据
 * @returns 匹配返回true 不匹配返回false
 */
function isMyFloat(floatValue){
  if(floatValue==''){
    return false;
  }
  floatValue = valueTrim(floatValue);
  var reg = /^(\d+)(\.\d+)$/;
  if(isNumber(floatValue)){
    return true;
  }
  if(floatValue.length>3){
    if(floatValue.substr(0, 1)=="0"){
      if(floatValue.substr(0, 2)!="0."){
        return false;
      }
    }
  }
  return reg.test(floatValue);
}
/**
 * 判断是否是汉字
 * @param charValue 要验证的数据
 * @returns 匹配返回true 不匹配返回false
 */
function isCharacter(charValue){
  var reg = /^[\u4e00-\u9fa5]{0,}$/;
  return reg.test(charValue);
}
/**
 * 验证座机号
 * @param telValue 要验证的座机号
 * @returns 匹配返回true 不匹配返回false
 */
function valiDateTel(telValue){
  var reg = /^(\(\d{3,4}\)|\d{3,4}-)?\d{7,8}$/;
  telValue = valueTrim(telValue);
  if(!reg.test(telValue)){
    return false;
  }
  return true;
} 

var Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1 ];  // 加权因子
var ValideCode = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ];      // 身份证验证位值.10代表X
/**
 * 验证身份证
 * @param idCard 需要验证的身份证号
 * @returns 匹配返回true 不匹配返回false
 */
function IdCardValidate(idCardValue) {
  //去掉字符串头尾空格
  idCardValue = valueTrim(idCardValue.replace(/ /g, ""));
  if (idCardValue.length == 15) {
    //进行15位身份证的验证
    return isValidityBrithBy15IdCard(idCardValue);
  } else if (idCardValue.length == 18) {
    // 得到身份证数组
    var a_idCard = idCardValue.split("");
    //进行18位身份证的基本验证和第18位的验证
    if(isValidityBrithBy18IdCard(idCardValue)&&isTrueValidateCodeBy18IdCard(a_idCard)){
      return true;
    }else {
      return false;
    }
  } else {
    return false;
  }
}
/**
 * 判断身份证号码为18位时最后的验证位是否正确
 * @param a_idCard 身份证号码数组
 * @return
 */
function isTrueValidateCodeBy18IdCard(a_idCard) {
  var sum = 0; // 声明加权求和变量
  if (a_idCard[17].toLowerCase() == 'x') {
    a_idCard[17] = 10;// 将最后位为x的验证码替换为10方便后续操作
  }
  for ( var i = 0; i < 17; i++) {
    sum += Wi[i] * a_idCard[i];// 加权求和
  }
  valCodePosition = sum % 11; // 得到验证码所位置
  if (a_idCard[17] == ValideCode[valCodePosition]) {
    return true;
  } else {
    return false;
  }
}
/**
 * 验证18位数身份证号码中的生日是否是有效生日
 * @param idCard 18位书身份证字符串
 * @return
 */
function isValidityBrithBy18IdCard(idCard18){
  var year = idCard18.substring(6,10);
  var month = idCard18.substring(10,12);
  var day = idCard18.substring(12,14);
  var temp_date = new Date(year,parseFloat(month)-1,parseFloat(day));
  // 这里用getFullYear()获取年份,避免千年虫问题
  if(temp_date.getFullYear()!=parseFloat(year)
     ||temp_date.getMonth()!=parseFloat(month)-1
     ||temp_date.getDate()!=parseFloat(day)){
      return false;
  }else{
    return true;
  }
}
/**
 * 验证15位数身份证号码中的生日是否是有效生日
 * @param idCard15 15位书身份证字符串
 * @return
 */
function isValidityBrithBy15IdCard(idCard15){
  var year = idCard15.substring(6,8);
  var month = idCard15.substring(8,10);
  var day = idCard15.substring(10,12);
  var temp_date = new Date(year,parseFloat(month)-1,parseFloat(day));
  // 对于老身份证中的你年龄则不需考虑千年虫问题而使用getYear()方法
  if(temp_date.getYear()!=parseFloat(year)
      ||temp_date.getMonth()!=parseFloat(month)-1
      ||temp_date.getDate()!=parseFloat(day)){
    return false;
  }else{
    return true;
  }
}
//去掉字符串头尾空格
function valueTrim(str) {
  return str.replace(/(^\s*)|(\s*$)/g, "");
} 

/**
 * 检验18位身份证号码(15位号码可以只检测生日是否正确即可,自行解决)
 * @param idCardValue 18位身份证号
 * @returns 匹配返回true 不匹配返回false
 */
function idCardVildate(cid){
  var arrExp = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2];//加权因子
  var arrValid = [1, 0, "X", 9, 8, 7, 6, 5, 4, 3, 2];//校验码
  var reg = /^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/;
  if(reg.test(cid)){
    var sum = 0, idx;
    for(var i = 0; i < cid.length - 1; i++){
      // 对前17位数字与权值乘积求和
      sum += parseInt(cid.substr(i, 1), 10) * arrExp[i];
    }
    // 计算模(固定算法)
    idx = sum % 11;
    // 检验第18为是否与校验码相等
    return arrValid[idx] == cid.substr(17, 1).toUpperCase();
  }else{
    return false;
  }
} 

/**
 * 获取指定日期之前或之后的第几天
 *
 * @param dayCount
 *      正数为以后时间,负数为以前时间 如:1表示为明天,-1为昨天
 *
 */
function getDateStr(dates, dayCount) {
  var dateTime = dayCount * 24 * 60 * 60 * 1000;
  var dd = new Date();
  if (dates == "") {
    dd = new Date();
  } else {
    dd = new Date(dates);
  }
  var dateNumber = dd.getTime() + dateTime;
  var newDate = new Date(dateNumber);
  var y = newDate.getFullYear();
  var m = newDate.getMonth() + 1;// 获取当前月份的日期
  var d = newDate.getDate();
  if (m < 10) {
    m = "0" + m;
  }
  if (d < 10) {
    d = "0" + d;
  }
  return y + "-" + m + "-" + d;
}
/**
 * 获取指定月份的之前或之后的第几个月
 *
 * @param dayCount
 *      正数为以后月份,负数为以前月份 如:1表示为下月,-1为上月
 *
 */
function getMonthStr(dates, monthCount) {
  var dd = new Date();
  if (dates == "") {
    dd = new Date();
  } else {
    dd = new Date(dates);
  }
  var y = dd.getFullYear();
  var m = dd.getMonth() + 1;// 获取当前月份的日期
  m = m + monthCount;
  if (m == 0) {
    m = "12";
    y = y - 1;
  } else if (m < 10) {
    m = "0" + m;
  } else if (m > 12) {
    m = m - 12;
    m = "0" + m;
    y = y + 1;
  }
  return y + "-" + m;
}
/**
*
*对val值为undefined返回“”,否则返回原值
*/
function dealNull(val) {
  if (typeof (val) == "undefined") {
    return "";
  } else {
    return val;
  }
}

总结

以上就是为大家整理的比较实用的js验证和数据处理的干货,对大家日常工作的时候很有帮助,建议大家收藏,方便以后查阅,谢谢大家对的支持。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索js
, js常用表单验证
, 验证数据类型
js表单数据验证
abaqus常用技巧总结、javascript 验证、javascript表单验证、javascript常用函数、javascript常用方法,以便于您获取更多的相关知识。

时间: 2024-11-17 11:26:41

常用的js验证和数据处理总结_javascript技巧的相关文章

Ajax使用原生态JS验证用户名是否存在_javascript技巧

直接上代码: reg_ajax.html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Ajax请求servlet实现用户名是否存在验证</title> </head> <body> <script type="text/javascript"> /** * 得到XMLHttpReque

js验证表单大全_javascript技巧

不错的JS验证~~~~~~~~~~~~~~~~~~~~~~~~~ 用途:校验ip地址的格式 输入:strIP:ip地址 返回:如果通过验证返回true,否则返回false: */ function isIP(strIP) { if (isNull(strIP)) return false; var re=/^(\d+)\.(\d+)\.(\d+)\.(\d+)$/g //匹配IP地址的正则表达式 if(re.test(strIP)) { if( RegExp.$1 <256 && R

js 验证身份证信息有效性_javascript技巧

以下是根据身份证号码编码规则,使用JS对其进行有效性验证代码 IdCard-Validate.js代码如下: 复制代码 代码如下: /** * 身份证15位编码规则:dddddd yymmdd xx p * dddddd:地区码 * yymmdd: 出生年月日 * xx: 顺序类编码,无法确定 * p: 性别,奇数为男,偶数为女 * <p /> * 身份证18位编码规则:dddddd yyyymmdd xxx y * dddddd:地区码 * yyyymmdd: 出生年月日 * xxx:顺序类

JS验证身份证有效性示例_javascript技巧

复制代码 代码如下: function checkIdcard(idcard){ var Errors=new Array( "验证通过", "身份证号码位数不对!", "身份证号码出生日期超出范围或含有非法字符!", "身份证号码校验错误!", "身份证地区非法!" ); var area={11:"北京",12:"天津",13:"河北",14:

常用的JS验证和函数汇总_基础知识

下面是我常用一些JS验证和函数,有一些验证我直接写到了对象的属性里面了,可以直接通过对象.方法来调用 复制代码 代码如下: //浮点数除法运算 function fdiv(a, b, n) {     if (n == undefined) { n = 2; }     var t1 = 0, t2 = 0, r1, r2;     try { t1 = a.toString().split(".")[1].length } catch (e) { }     try { t2 = b

php常用表单验证类用法实例_php技巧

本文实例讲述了php常用表单验证类用法.分享给大家供大家参考.具体如下: <?php /** * 页面作用:常用表单验证类 * 作 者:欣然随风 * QQ:276624915 */ class class_post { //验证是否为指定长度的字母/数字组合 function fun_text1($num1,$num2,$str) { Return (preg_match("/^[a-zA-Z0-9]{".$num1.",".$num2."}$/&q

js调试系列 初识控制台_javascript技巧

写在最开头:其实我以前就在考虑要不要写这个东西,因为这个东西确实不难,但是为什么会有这么多人问,他们问的不是怎么用控制台,而是不知道控制台能干嘛,他们也知道有 console.log 之类的东西,但他们不知道为什么要用这么长的字符串代替 alert 输出信息.在他们眼里 alert 足以.好吧,我承认小小的吐槽了下,不过这个系列我只打算介绍下调试的基本知识,不会涉及太深,因为深入的东西结合js知识,如果你js没到一个境界,我就算教你调试bug,破解一些插件之类的,你也根本不知道我在做什么.我的目

Javascript验证上传图片大小[前台处理]_javascript技巧

需求分析: 在做上传图片的时候,如果不限制上传图片大小,后果非常的严重.那么我们怎样才可以解决一个棘手的问题呢?有两种方式: 1)后台处理: 也就是AJAX POST提交到后台,把图片上传到服务器上,然后获得该图片大小做处理. 2)前台处理: 也就是利用Javascript获取该图片大小. 显然第一种方式,很不好.因为需要把文件先上传到服务器上,如果文件很大的话,在加上网不是很快,需要等待好长时间,治标不治本. 功能解析: 在这里我只介绍IE与FireFox两个浏览器的不同做法. IE6: 关键

利用JS提交表单的几种方法和验证(必看篇)_javascript技巧

工作中发现表单提交方便的问题,很多时候IE下提交好好的,打了火狐下就出现了问题,利用提交按钮就不成功了,于是利用JS的方式就成功了,也不知道为什么.在导师的催促下就总结出以下的几种常用表单提交的方法. 第一种方式:表单提交,在form标签中增加onsubmit事件来判断表单提交是否成功 <script type="text/javascript"> function validate(obj) { if (confirm("提交表单?")) { aler