整理的一些常用的js表单验证

简介: /** * 验证时间 * @param dataValue 格式为:YYYY-MM-DD * @returns 匹配返回true 不匹配返回false */function valiDate(dateValue){ var result = dateValue.
 
/**
 * 验证时间
 * @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) {
	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;
	}
	//判断当数字只有1位时
	if(numberValue.length<2){
		return reg1.test(numberValue);
	}
	return reg2.test(numberValue);;
}
/***
 * 金额
 * @param value
 * @returns
 */
function isMoney(value) {
	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);
}

/**
 * 验证是否是浮点数
 * @param floatValue 要验证的数据
 * @returns 匹配返回true 不匹配返回false
 */
function isMyFloat(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}$/;
	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;
    }
}


相关文章
|
4月前
|
JavaScript 前端开发
JavaScript事件监听、常见事件及表单验证
JavaScript事件监听、常见事件及表单验证
17 0
|
3月前
|
移动开发 JavaScript 前端开发
分享21个JS抽奖转盘特效,36个JS表单验证,31个JS进度条,总有一款适合您
分享21个JS抽奖转盘特效,36个JS表单验证,31个JS进度条,总有一款适合您
24 0
|
3月前
|
JavaScript 前端开发 安全
使用JavaScript实现动态表单验证(下)
使用JavaScript实现动态表单验证
|
4月前
|
JavaScript 前端开发
原生JavaScript之dom添加表单验证
原生JavaScript之dom添加表单验证
25 2
原生JavaScript之dom添加表单验证
|
5月前
|
JavaScript
js常用表单验证规则
js常用表单验证规则
58 0
|
6月前
|
自然语言处理 JavaScript 前端开发
javascript表单验证
javascript表单验证
|
JavaScript 前端开发
JavaScript 表单验证
JavaScript 表单验证
34 0
|
JavaScript 前端开发 UED
如何用JavaScript实现表单验证
在Web开发中,表单验证是非常重要的一部分。通过表单验证,可以保证用户输入的数据格式正确,有效地避免后端数据异常。在本文中,我们将介绍如何使用JavaScript实现表单验证。
83 0
|
JavaScript 前端开发
JavaScript使用正则表达式进行邮箱表单验证实例
JavaScript使用正则表达式进行邮箱表单验证实例
64 0
|
JavaScript 前端开发 数据安全/隐私保护
JavaScript学习笔记(三),js中的事件,this的使用、表单验证、省市级联下拉框案例
JavaScript学习笔记(三),js中的事件,this的使用、表单验证、省市级联下拉框案例
130 0
JavaScript学习笔记(三),js中的事件,this的使用、表单验证、省市级联下拉框案例