码迷,mamicode.com
首页 > Web开发 > 详细

jquery validate.addMethod 正则表达式 (自定义验证方法)

时间:2014-11-12 13:40:18      阅读:332      评论:0      收藏:0      [点我收藏+]

标签:blog   http   io   ar   使用   sp   for   on   art   

 

  项目中使用的jQuery添加的校验的方法

$(document).ready(function(){       
  5bubuko.com,布布扣         
  6bubuko.com,布布扣/* 设置默认属性 */       
  7bubuko.com,布布扣$.validator.setDefaults({       
  8bubuko.com,布布扣    submitHandler: function(form) {    
  9bubuko.com,布布扣        form.submit();    
 10bubuko.com,布布扣    }       
 11bubuko.com,布布扣});   
 12bubuko.com,布布扣  
 13bubuko.com,布布扣// 字符验证       
 14bubuko.com,布布扣jQuery.validator.addMethod("stringCheck", function(value, element) {       
 15bubuko.com,布布扣    return this.optional(element) || /^[\u0391-\uFFE5\w]+$/.test(value);       
 16bubuko.com,布布扣}, "只能包括中文字、英文字母、数字和下划线");   
 17bubuko.com,布布扣  
 18bubuko.com,布布扣// 中文字两个字节       
 19bubuko.com,布布扣jQuery.validator.addMethod("byteRangeLength", function(value, element, param) {       
 20bubuko.com,布布扣    var length = value.length;       
 21bubuko.com,布布扣    for(var i = 0; i < value.length; i++){       
 22bubuko.com,布布扣        if(value.charCodeAt(i) > 127){       
 23bubuko.com,布布扣        length++;       
 24bubuko.com,布布扣        }       
 25bubuko.com,布布扣    }       
 26bubuko.com,布布扣    return this.optional(element) || ( length >= param[0] && length <= param[1] );       
 27bubuko.com,布布扣}, "请确保输入的值在3-15个字节之间(一个中文字算2个字节)");   
 28bubuko.com,布布扣  
 29bubuko.com,布布扣// 身份证号码验证       
 30bubuko.com,布布扣jQuery.validator.addMethod("isIdCardNo", function(value, element) {       
 31bubuko.com,布布扣    return this.optional(element) || isIdCardNo(value);       
 32bubuko.com,布布扣}, "请正确输入您的身份证号码");
 33bubuko.com,布布扣     
 34bubuko.com,布布扣// 手机号码验证       
 35bubuko.com,布布扣jQuery.validator.addMethod("isMobile", function(value, element) {       
 36bubuko.com,布布扣    var length = value.length;   
 37bubuko.com,布布扣    var mobile = /^(((13[0-9]{1})|(15[0-9]{1}))+\d{8})$/;   
 38bubuko.com,布布扣    return this.optional(element) || (length == 11 && mobile.test(value));       
 39bubuko.com,布布扣}, "请正确填写您的手机号码");       
 40bubuko.com,布布扣     
 41bubuko.com,布布扣// 电话号码验证       
 42bubuko.com,布布扣jQuery.validator.addMethod("isTel", function(value, element) {       
 43bubuko.com,布布扣    var tel = /^\d{3,4}-?\d{7,9}$/;    //电话号码格式010-12345678   
 44bubuko.com,布布扣    return this.optional(element) || (tel.test(value));       
 45bubuko.com,布布扣}, "请正确填写您的电话号码");   
 46bubuko.com,布布扣  
 47bubuko.com,布布扣// 联系电话(手机/电话皆可)验证   
 48bubuko.com,布布扣jQuery.validator.addMethod("isPhone", function(value,element) {   
 49bubuko.com,布布扣    var length = value.length;   
 50bubuko.com,布布扣    var mobile = /^(((13[0-9]{1})|(15[0-9]{1}))+\d{8})$/;   
 51bubuko.com,布布扣    var tel = /^\d{3,4}-?\d{7,9}$/;   
 52bubuko.com,布布扣    return this.optional(element) || (tel.test(value) || mobile.test(value));   
 53bubuko.com,布布扣  
 54bubuko.com,布布扣}, "请正确填写您的联系电话");   
 55bubuko.com,布布扣     
 56bubuko.com,布布扣// 邮政编码验证       
 57bubuko.com,布布扣jQuery.validator.addMethod("isZipCode", function(value, element) {       
 58bubuko.com,布布扣    var tel = /^[0-9]{6}$/;       
 59bubuko.com,布布扣    return this.optional(element) || (tel.test(value));       
 60bubuko.com,布布扣}, "请正确填写您的邮政编码");    
 61bubuko.com,布布扣  
 62bubuko.com,布布扣//开始验证   
 63bubuko.com,布布扣$(‘#submitForm‘).validate({   
 64bubuko.com,布布扣    /* 设置验证规则 */  
 65bubuko.com,布布扣    rules: {   
 66bubuko.com,布布扣        username: {   
 67bubuko.com,布布扣            required:true,   
 68bubuko.com,布布扣            stringCheck:true,   
 69bubuko.com,布布扣            byteRangeLength:[3,15]   
 70bubuko.com,布布扣        },   
 71bubuko.com,布布扣        email:{   
 72bubuko.com,布布扣            required:true,   
 73bubuko.com,布布扣            email:true  
 74bubuko.com,布布扣        },   
 75bubuko.com,布布扣        phone:{   
 76bubuko.com,布布扣            required:true,   
 77bubuko.com,布布扣            isPhone:true  
 78bubuko.com,布布扣        },   
 79bubuko.com,布布扣        address:{   
 80bubuko.com,布布扣            required:true,   
 81bubuko.com,布布扣            stringCheck:true,   
 82bubuko.com,布布扣            byteRangeLength:[3,100]   
 83bubuko.com,布布扣        }   
 84bubuko.com,布布扣    },   
 85bubuko.com,布布扣       
 86bubuko.com,布布扣    /* 设置错误信息 */  
 87bubuko.com,布布扣    messages: {   
 88bubuko.com,布布扣        username: {       
 89bubuko.com,布布扣            required: "请填写用户名",   
 90bubuko.com,布布扣            stringCheck: "用户名只能包括中文字、英文字母、数字和下划线",   
 91bubuko.com,布布扣            byteRangeLength: "用户名必须在3-15个字符之间(一个中文字算2个字符)"       
 92bubuko.com,布布扣        },   
 93bubuko.com,布布扣        email:{   
 94bubuko.com,布布扣            required: "请输入一个Email地址",   
 95bubuko.com,布布扣            email: "请输入一个有效的Email地址"  
 96bubuko.com,布布扣        },   
 97bubuko.com,布布扣        phone:{   
 98bubuko.com,布布扣            required: "请输入您的联系电话",   
 99bubuko.com,布布扣            isPhone: "请输入一个有效的联系电话"  
100bubuko.com,布布扣        },   
101bubuko.com,布布扣        address:{   
102bubuko.com,布布扣            required: "请输入您的联系地址",   
103bubuko.com,布布扣            stringCheck: "请正确输入您的联系地址",   
104bubuko.com,布布扣            byteRangeLength: "请详实您的联系地址以便于我们联系您"  
105bubuko.com,布布扣        }   
106bubuko.com,布布扣    },   
107bubuko.com,布布扣       
108bubuko.com,布布扣   /* 设置验证触发事件 */  
109bubuko.com,布布扣    focusInvalid: false,   
110bubuko.com,布布扣    onkeyup: false,   
111bubuko.com,布布扣       
112bubuko.com,布布扣    /* 设置错误信息提示DOM */  
113bubuko.com,布布扣    errorPlacement: function(error, element) {       
114bubuko.com,布布扣        error.appendTo( element.parent());       
115bubuko.com,布布扣    },     
116bubuko.com,布布扣       
117bubuko.com,布布扣});   
118bubuko.com,布布扣  
119bubuko.com,布布扣});

 

 

supplier-commons-vacation.js

 

 //定义订单的公共的函数方法
 function define_common_method(){
 
    //设置默认的操作
     $.validator.setDefaults({    
     submitHandler: function(form) { form.submit(); }    
        }); 
   
     //添加自定义校验函数
     $.validator.addMethod("charNo",function(value,element) {    
    var length = value.length;  
    var your_tel =/[\W]/g;
    return this.optional(element) || (length<=8&&!your_tel.test(value));   
  },"请输入英文字符或数字!");
  
  //添加验证操作名称的校验函数
  $.validator.addMethod("charString",function(value,element) {    
      var length = value.length;  
      var your_tel =/[^\a-zA-Z\u4E00-\u9FA5]/g;
      var your_tel2=/^[A-Za-z]*$/;
      return this.optional(element) || (length<=20&&!your_tel.test(value));   
  },"请输入中文或英文名称"); 
  
  //验证手机号码(仅仅13和15开头)
  $.validator.addMethod("isPhone", function(value,element) {   
           var length = value.length;   
        var mobile = /^(((13[0-9]{1})|(15[0-9]{1}))+\d{8})$/;   
         var tel = /^\d{3,4}-?\d{7,9}$/;   
        return this.optional(element) || (tel.test(value) || mobile.test(value));   
         }, "请正确填写您的联系电话或者手机");   
  
 }

 

 

supplier-finance.js

jQuery(function($) {
 
 //绑定所有的事件
 $(document).ready(function() {
  bind_component_event();
 });
 
 
 //绑定的公共的事件
 function bind_component_event() {
    //定义一些公共的方法
    define_common_method();
  
    //环游供应商付款的验证(度假)  
    bind_checkCondition_component_event();
    
    
    //环游供应商付款验证的(供应商)
    bind_supplierConditionForm_component_event();
 }
 
 //环游供应商付款(度假)的验证  
 function bind_checkCondition_component_event() {
  
  //待收款款订单验证
  $("#checkConditionForm").validate({
   event: "submit",
   errorPlacement: function(error, element) {
   },
   rules:{
     "searchCon.accountNo":{
      charNo:true
     },
     "searchCon.supplierName":{
      charString:true
     }
    },
    messages:{
     "searchCon.accountNo":{
        charNo:"请输入正确的对账编号!"
       },
       "searchCon.supplierName":{
        charString:"请输入正确的供应商名称!"
       }
    },
    
    //设置验证触发事件
   focusInvalid:false,
   onkeyup:false,
            
         //设置错误信息提示DOM    
   errorPlacement:function(error,element){
      error.appendTo(element.parent());
   }
    
    
  });
 }
 //环游供应商付款的验证(供应商)  
 function bind_supplierConditionForm_component_event() {
  
  //待收款款订单验证
  $("#supplierConditionForm").validate({
   event: "submit",
   errorPlacement: function(error, element) {
   },
   rules:{
     "searchCon.accountNo":{
      charNo:true
     },
     "searchCon.supplierName":{
      charString:true
     }
    },
    messages:{
     "searchCon.accountNo":{
        charNo:"请输入正确的对账编号!"
       },
       "searchCon.supplierName":{
        charString:"请输入正确的供应商名称!"
       }
    },
    
    //设置验证触发事件
   focusInvalid:false,
   onkeyup:false,
            
         //设置错误信息提示DOM    
   errorPlacement:function(error,element){
      error.appendTo(element.parent());
   }
  });
 }
 
});

 

 

关于jQuery的校验的API

 

http://docs.jquery.com/Plugins/Validation/Validator/addMethod

 


http://www.shopxx.net/html/news/2009/1201/59.html

http://jquery.bassistance.de/api-browser/plugins.html

jquery validate.addMethod 正则表达式 (自定义验证方法)

标签:blog   http   io   ar   使用   sp   for   on   art   

原文地址:http://www.cnblogs.com/goodbeypeterpan/p/4091953.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!