validate.js 正则表达完成input框的各种判断

/*
 * 校验是正的小数 小数点后2位
 */
function validIntAndPoint(val){
	var regu=/^[0-9]+[\.][0-9]{0,2}$/;
	var re = new RegExp(regu);
	return  re.test(val);
}
/*
 * 校验是正的小数 小数点后2位 或整的数
 */
function validIntAndPoint2(val){
	var regu1=/^[0-9]+[\.][0-9]{0,2}$/;
	var re1 = new RegExp(regu1);
	var regu2=/^[0-9]+[\.][0-9]{0,1}$/;
	var re2 = new RegExp(regu2);
	var regu3=/^[0-9]+$/;
	var re3 = new RegExp(regu3);
	return  re1.test(val)||re2.test(val)||re3.test(val);
}
/*
 * 校验是正的小数 小数点后2位 或整的数
 */
function validIntAndPoint3(val){
	var regu1=/^\d{1,1}+[\.][0-9]{0,2}$/;
	var re1 = new RegExp(regu1);
	var regu2=/^\d{1,1}+[\.][0-9]{0,1}$/;
	var re2 = new RegExp(regu2);
	var regu3=/^\d{1,1}+$/;
	var re3 = new RegExp(regu3);
	return  re1.test(val)||re2.test(val)||re3.test(val);
}
/*
 * 校验是正整数
 */
function validInt(val){
	var regu=/^[0-9]+$/;
	var re = new RegExp(regu);
	return  re.test(val);
}
/**
 * 验证是整数
 * Number.isInteger(obj.value)  --适用于ES6
 */
function ValidatInteger(obj) {
    var reg = /^[1-9]\d*$/
    if (!reg.test($(obj).val())) {
        $(obj).val(0);
    }
}
/*
 * 校验是字母和数字
 */
function validNumOrLetter(val){
	var regu=/^[A-Za-z0-9]+$/;
	var re = new RegExp(regu);
	return  re.test(val);
}

/*
 * 校验是邮箱
 */
function validEmail(val){
	var regu=/^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/;
	var re = new RegExp(regu);
	return  re.test(val);
}

function validTel(val){
	var isPhone = /^([0-9]{3,4}-)?[0-9]{7,8}$/;
	var isMob=/^((\+?86)|(\(\+86\)))?(13[0123456789][0-9]{8}|15[0123456789][0-9]{8}|18[012356789][0-9]{8}|147[0-9]{8}|1349[0-9]{7})$/;
	var re1 = new RegExp(isPhone);
	var re2 = new RegExp(isMob);
	return re1.test(val)||re2.test(val);
}

/*
 * 验证身份证
 */
function IdentityCodeValid(code) { 
    var city={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 tip = "";
    var pass= true;
    /* if(!code || !/^\d{6}(18|19|20)?\d{2}(0[1-9]|1[0-2])(0[1-9]|[12]\d|3[01])\d{3}(\d|X)$/i.test(code)){
        tip = "身份证号格式错误";
        pass = false;
    } */
    if(!code || !/^[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{3}([0-9]|X)$/i.test(code)){
        tip = "身份证号格式错误";
        pass = false;
    }
    
   else if(!city[code.substr(0,2)]){
        tip = "地址编码错误";
        pass = false;
    }
    else{
        //18位身份证需要验证最后一位校验位
        if(code.length == 18){
            code = code.split('');
            //∑(ai×Wi)(mod 11)
            //加权因子
            var factor = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ];
            //校验位
            var parity = [ 1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2 ];
            var sum = 0;
            var ai = 0;
            var wi = 0;
            for (var i = 0; i < 17; i++)
            {
                ai = code[i];
                wi = factor[i];
                sum += ai * wi;
            }
            var last = parity[sum % 11];
            if(parity[sum % 11] != code[17]){
                tip = "校验位错误";
                pass =false;
            }
        }
    }
    if(!pass);
    return pass;
}

/*
 * 比较两个时间的大小
 */
function compareTime(val1,val2){
	 var t1 = new Date(val1);   
	 var t2 = new Date(val2);  
	 if(t2-t1<0){
		 return false;
	 }else{
		 return true;
	 }
}

function clearNoNum(obj){
	obj.value = obj.value.replace(/[^\d.]/g,""); //清除"数字"和"."以外的字符
	obj.value = obj.value.replace(/^\./g,""); //验证第一个字符是数字而不是
	obj.value = obj.value.replace(/\.{2,}/g,"."); //只保留第一个. 清除多余的
	obj.value = obj.value.replace(".","$#$").replace(/\./g,"").replace("$#$",".");
	obj.value = obj.value.replace(/^(\-)*(\d+)\.(\d\d).*$/,'$1$2.$3'); //只能输入两个小数
}

/*
 * 校验不能只输入空格或者不输入
 */
function valid(val){
	if (val.length == 0) 
	{ 
		return false;
	}
	var regu = "^[ ]+$";
	var re = new RegExp(regu);
	if(re.test(val)){
		return false;
	}
	return true;
}
/*
 * 验证为正数
 */
function validatePositive(num)
{
	var reg = /^\d+(?=\.{0,1}\d+$|$)/
	if(reg.test(num)) return true;
	return false ;  
}
/* 
 * 判断图片类型 
 *  
 * @param ths  
 *          type="file"的javascript对象 
 * @return true-符合要求,false-不符合 
 */  
function checkImgType(ths){  
    if (ths == "") {    
        return false;  
    } else {  
        if (!/\.(gif|jpg|jpeg|bmp|png|GIF|JPG|PNG|BMP)$/.test(ths)) {    
            return false;  
        }  
    }  
    return true;  
} 
/* 
 * 判断视频类型 
 *  
 * @param ths  
 *          type="file"的javascript对象 
 * @return true-符合要求,false-不符合 
 */  
function checkVideoType(ths){  
    if (ths == "") {    
        return false;  
    } else {  
        if (!/\.(MP4|AVI|MKV|WMV|RM|RMVB|3GP|MOV|M4V|FLV|mp4|avi|mkv|wmv|rm|rmvb|3gp|mov|m4v|flv)$/.test(ths)) {               
            ths = "";  
            return false;  
        }  
    }  
    return true;  
}

评论 17
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值