jquery ui各种验证代码

//表单验证扩展
$.extend($.fn.validatebox.defaults.rules,
	{    //验证中文  
		CHS:{
			validator:function(value){
				return /^[\u0391-\uFFE5]+$/.test(value);
			},
			message:"只能输入汉字."
		},
		//字符验证
		stringCheck:{
			validator:function(value){
				return /^[\u0391-\uFFE5\w]+$/.test(value);
			},
			message:"只能包括中文字、英文字母、数字和下划线."
		},
		//验证中文,英文,数字
		stringCheckSub:{
			validator:function(value){
				return /^[a-zA-Z0-9\u4E00-\u9FA5]+$/.test(value);
			},
			message:"只能包括中文字、英文字母、数字."
		},
		englishCheckSub:{
			validator:function(value){
				return /^[a-zA-Z0-9]+$/.test(value);
			},
			message:"只能包括英文字母、数字."
		},
		numberCheckSub:{
			validator:function(value){
				return /^[0-9]+$/.test(value);
			},
			message:"只能输入数字."
		},
		//手机号码验证
		mobile:{
			validator:function(value){
				var reg = /^(((13[0-9]{1})|(14[0-9]{1})|(15[0-9]{1})|(18[0-9]{1}))+\d{8})$/;				
				return value.length == 11 && reg.test(value);
			},
			message:"请正确填写您的手机号码."
		},
		//电话号码验证
		telephone:{
			validator:function(value){
				//电话号码格式010-12345678
				var reg = /^\d{3,4}?\d{7,8}$/;				
				return reg.test(value);
			},
			message:"请正确填写您的电话号码."
		},
		//联系电话(手机/电话皆可)验证 
		mobileTelephone:{
			validator:function(value){
				var cmccMobile = /^(((13[0-9]{1})|(14[0-9]{1})|(15[0-9]{1})|(18[0-9]{1}))+\d{8})$/;
				var tel = /^\d{3,4}?\d{7,8}$/;
				return tel.test(value) || (value.length == 11 && cmccMobile.test(value));
			},
			message:"请正确填写您的联系电话."
		},
		//验证国内邮编验证
		zipCode:{
			validator:function(value){
				var reg = /^[1-9]\d{5}$/;
				return reg.test(value);
			},
			message:"邮编必须长短0开端的6位数字."
		},
		//身份证号码验证 
		idCardNo:{
			validator:function(value){
				return isIdCardNo(value); 
			},
			message:"请正确输入您的身份证号码."
		},
		
		//验证两个不同时为空
		//可以自定义提示信息
		
		   allNotNull:{
			validator:function(toValue,fromValue){
				if(fromValue ==null || fromValue.length ==0 || fromValue[0]==null || fromValue[0]==""){
					if(toValue ==null || toValue.length ==0 || toValue[0]==null || toValue[0]==""){
						 $.fn.validatebox.defaults.rules.compareDigit.message="中,英.文名不可同时为空 ";
						 return false;
					}else{
						return true;
						}
				}else
					{return true;}
			},
			message:""
		},
		
		
		
		
		//数字验证大小,结束值应该大于开始值
		//可以自定义提示信息
		compareDigit:{
			validator:function(toValue,fromValue){
				if(fromValue ==null || fromValue.length ==0 || fromValue[0]==null || fromValue[0]==""){
					return true;
				}
				if(parseFloat(toValue) > parseFloat(fromValue[0])){
					return true;
				}else{
					if(fromValue.length >= 2){
						$.fn.validatebox.defaults.rules.compareDigit.message = fromValue[1];
					}else{
						$.fn.validatebox.defaults.rules.compareDigit.message = '结束值应该大于开始值';
					}
					return false
				}
			},
			message:""
		},
		//日期、时间验证大小,结束日期应该大于开始日期
		//可以自定义提示信息
		compareDate:{
			validator:function(toDate,param){
				if(param ==null || param.length ==0 || param[0]==null || param[0]==""){
					return true;
				}
				if(toDate > param[0]){
					return true;
				}else{
					if(param.length >= 2){
						$.fn.validatebox.defaults.rules.compareDate.message = param[1];
					}
					else {
						$.fn.validatebox.defaults.rules.compareDate.message = '结束日期应该大于开始日期';
					}
					return false
				}
			},
			message:''
		}
		//到服务器端验证
		/*remote:{
			validator:function(value,param){
				var params = {};
				params[param[1]] = value;
				$.post(param[0],params,function(data){
					if(!data.msg){
						$.fn.validatebox.defaults.rules.account.message = param[2];
					}					
					return data.msg;
				});
			},
			message:""
		}*/
	}
)

//--身份证号码验证-支持新的带x身份证
function isIdCardNo(num) 
{
    var factorArr = new Array(7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2,1);
    var error;
    var varArray = new Array();
    var intValue;
    var lngProduct = 0;
    var intCheckDigit;
    var intStrLen = num.length;
    var idNumber = num;    
    // initialize
    if ((intStrLen != 15) && (intStrLen != 18)) {
        //error = "输入身份证号码长度不对!";
        //alert(error);
        //frmAddUser.txtIDCard.focus();
        return false;
    }    
    // check and set value
    for(i=0;i<intStrLen;i++) {
        varArray[i] = idNumber.charAt(i);
        if ((varArray[i] < '0' || varArray[i] > '9') && (i != 17)) {
            //error = "错误的身份证号码!.";
            //alert(error);
            //frmAddUser.txtIDCard.focus();
            return false;
        } else if (i < 17) {
            varArray[i] = varArray[i]*factorArr[i];
        }
    }
    if (intStrLen == 18) {
        //check date
        var date8 = idNumber.substring(6,14);
        if (isDate8(date8) == false) {
            //error = "身份证中日期信息不正确!.";
            //alert(error);
            return false;
        }        
        // calculate the sum of the products
        for(i=0;i<17;i++) {
            lngProduct = lngProduct + varArray[i];
        }        
        // calculate the check digit
        intCheckDigit = 12 - lngProduct % 11;
        switch (intCheckDigit) {
            case 10:
                intCheckDigit = 'X';
                break;
            case 11:
                intCheckDigit = 0;
                break;
            case 12:
                intCheckDigit = 1;
                break;
        }        
        // check last digit
        if (varArray[17].toUpperCase() != intCheckDigit) {
            //error = "身份证效验位错误!...正确为: " + intCheckDigit + ".";
            //alert(error);
            return false;
        }
    } 
    else{        //length is 15
        //check date
        var date6 = idNumber.substring(6,12);
        if (isDate6(date6) == false) {
            //alert("身份证日期信息有误!.");
            return false;
        }
    }
    //alert ("Correct.");
    return true;
}

/**
 * 判断是否为“YYYYMM”式的时期
 *
 */
function isDate6(sDate) {
   if(!/^[0-9]{6}$/.test(sDate)) {
      return false;
   }
   var year, month, day;
   year = sDate.substring(0, 4);
   month = sDate.substring(4, 6);
   if (year < 1700 || year > 2500) return false
   if (month < 1 || month > 12) return false
   return true
}
/**
 * 判断是否为“YYYYMMDD”式的时期
 *
 */
function isDate8(sDate) {
   if(!/^[0-9]{8}$/.test(sDate)) {
      return false;
   }
   var year, month, day;
   year = sDate.substring(0, 4);
   month = sDate.substring(4, 6);
   day = sDate.substring(6, 8);
   var iaMonthDays = [31,28,31,30,31,30,31,31,30,31,30,31]
   if (year < 1700 || year > 2500) return false
   if (((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0)) iaMonthDays[1]=29;
   if (month < 1 || month > 12) return false
   if (day < 1 || day > iaMonthDays[month - 1]) return false
   return true
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
jQuery UI标准后台页面演示系统说明 系统的设计目的 我做B/S软件开发,基本上还是采用原型法的--嗯,好吧,可能原型法还是往自己脸上贴金了。俗一点说吧,就是和客户定一个尽可能详细的功能描述文档,然后按文档写完程序,再回交给客户演示,客户观看演示后会提出很多意见,再按这些意见修改,然后再演示,如此循环往复,直至交稿。与最初的演示稿相比,最后的完成稿出入很大,大量的工作,其实都是浪费的。我就想,能不能以后先做一个快速生成的演示系统,用户确认后再真正制作程序呢?于是就有了这个演示系统的产生。 作为系统的第一个版本,这个系统功能比较简单。我之前的设想,是用zend framework框架设计一个接近CMS功能的后台,统一用户管理、文章发布等常用功能,但这么一来,系统的适用范围就小了。所以,先做一套极简易的小架构,即使没有学过PHP的.net/java程序员,应该也能很容易看懂并上手使用,甚至把它改成其它语言的版本。 目前的这个版本,最值得推荐的功能在于,jQuery代码是一次载入的,使用这套系统进行开发,程序员可以完全不懂jQuery,而仍能享用jQuery的种种便利。 0.1版系统特点介绍 • 集成了jQuery UI的风琴盒、页标签特效、ajaxForm表单递交和validate表单验证功能,无需程序员学习这些功能,按常规方式编程即可自动调用。 • 保持了与jqueryui的完全兼容,可以自行前往www.jqueryui.com网站下载更多酷炫界面风格,甚至自定义风格 • 涉及的PHP代码极少且足够建议,非PHP程序员也能使用 • 对系统要求非常低,只要普通PHP程序能够运行即可 系统实际使用步骤 1. 复制(解压)文件夹到网站测试文档根目录(apache系统下一般是htdocs),即可直接访问 2. 修改config.php文件中的数组,即可快速生成界面结构 3. config.php中的$tabs数组就是页面标签内容,其中的url可自行指定或新建文件,文件格式可以参照admin.php、helper.php等文件 4. 如果$tab中url指向的文件中需要包含表单,按常规写法即可,无需特殊代码即可自动以ajax方式递交 5. 如果表单需要ajax方式验证,可以给相应的表单项添加class,可参见systemsetting.php和address.php文件,也可自行网上搜索和阅读jquery.validate.js的帮助文档 6. 演示中的项目,只有核心系统下的后台首页和系统设置有效,其它都只是点缀

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值