`
zhangzuanqian
  • 浏览: 268816 次
  • 来自: ...
社区版块
存档分类
最新评论

jquery validate.addMethod 正则表达式

 
阅读更多

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

$(document).ready(function(){
5
6/**//* 设置默认属性 */
7$.validator.setDefaults({
8 submitHandler: function(form){
9 form.submit();
10 }

11}
);
12
13// 字符验证
14jQuery.validator.addMethod("stringCheck",function(value, element){
15returnthis.optional(element)||/^[\u0391-\uFFE5\w]+$/.test(value);
16}
,"只能包括中文字、英文字母、数字和下划线");
17
18// 中文字两个字节
19jQuery.validator.addMethod("byteRangeLength",function(value, element, param){
20var length= value.length;
21for(var i= 0; i< value.length; i++){
22if(value.charCodeAt(i)>127){
23 length++;
24 }

25 }

26returnthis.optional(element)|| ( length>= param[0]&& length <= param[1] );
27}
,"请确保输入的值在3-15个字节之间(一个中文字算2个字节)");
28
29// 身份证号码验证
30jQuery.validator.addMethod("isIdCardNo",function(value, element){
31returnthis.optional(element)|| isIdCardNo(value);
32}
,"请正确输入您的身份证号码");

33
34// 手机号码验证
35jQuery.validator.addMethod("isMobile",function(value, element){
36var length= value.length;
37var mobile= /^(((13[0-9]{1})|(15[0-9]{1}))+\d{8})$/;
38returnthis.optional(element)|| (length== 11&& mobile.test(value));
39}
,"请正确填写您的手机号码");
40
41// 电话号码验证
42jQuery.validator.addMethod("isTel",function(value, element){
43var tel= /^\d{3,4}-?\d{7,9}$/;//电话号码格式010-12345678
44returnthis.optional(element)|| (tel.test(value));
45}
,"请正确填写您的电话号码");
46
47// 联系电话(手机/电话皆可)验证
48jQuery.validator.addMethod("isPhone",function(value,element){
49var length= value.length;
50var mobile= /^(((13[0-9]{1})|(15[0-9]{1}))+\d{8})$/;
51var tel= /^\d{3,4}-?\d{7,9}$/;
52returnthis.optional(element)|| (tel.test(value)|| mobile.test(value));
53
54}
,"请正确填写您的联系电话");
55
56// 邮政编码验证
57jQuery.validator.addMethod("isZipCode",function(value, element){
58var tel= /^[0-9]{6}$/;
59returnthis.optional(element)|| (tel.test(value));
60}
,"请正确填写您的邮政编码");
61
62//开始验证
63$('#submitForm').validate({
64/**//* 设置验证规则 */
65 rules: {
66 username: {
67 required:true,
68 stringCheck:true,
69 byteRangeLength:[3,15]
70 }
,
71 email:{
72 required:true,
73 email:true
74 }
,
75 phone:{
76 required:true,
77 isPhone:true
78 }
,
79 address:{
80 required:true,
81 stringCheck:true,
82 byteRangeLength:[3,100]
83 }

84 }
,
85
86/**//* 设置错误信息 */
87 messages: {
88 username: {
89 required:"请填写用户名",
90 stringCheck:"用户名只能包括中文字、英文字母、数字和下划线",
91 byteRangeLength:"用户名必须在3-15个字符之间(一个中文字算2个字符)"
92 }
,
93 email:{
94 required:"请输入一个Email地址",
95 email:"请输入一个有效的Email地址"
96 }
,
97 phone:{
98 required:"请输入您的联系电话",
99 isPhone:"请输入一个有效的联系电话"
100 }
,
101 address:{
102 required:"请输入您的联系地址",
103 stringCheck:"请正确输入您的联系地址",
104 byteRangeLength:"请详实您的联系地址以便于我们联系您"
105 }

106 }
,
107
108/* 设置验证触发事件*/
109 focusInvalid:false,
110 onkeyup:false,
111
112/**//* 设置错误信息提示DOM */
113 errorPlacement: function(error, element){
114 error.appendTo( element.parent());
115 }
,
116
117}
);
118
119});

 

 

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

 

1.非负整数 /^\d+$/
2.正整数 /^[0-9]*[1-9][0-9]*$/
3.非正整数 /^((-\d+)|(0+))$/
4.负整数 /^-[0-9]*[1-9][0-9]*$/
5.整数 /^-?\d+$/
6.非负浮点数 /^\d+(\.\d+)?$/
7.正浮点数 /^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$/
8.非正浮点数 /^((-\d+(\.\d+)?)|(0+(\.0+)?))$/
9.负浮点数 /^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$/
10.浮点数 /^(-?\d+)(\.\d+)?$/
11.数字 /^\d+(\.
{1}\d+)?$/
12.由26个英文字母组成的字符串 /^[A-Za-z]+$/
13.由26个英文字母的大写组成的字符串 /^[A-Z]+$/
14.由26个英文字母的小写组成的字符串 /^[a-z]+$/
15.由数字和26个英文字母组成的字符串 /^[A-Za-z0-9]+$/
16.由数字、26个英文字母或者下划线组成的字符串 /^\w+$/
17.匹配所有单字节长度的字符组成的字符串 /^[\x00-\xff]+$/
18.匹配所有双字节长度的字符组成的字符串 /^[^\x00-\xff]+$/
19.字符串是否含有双字节字 /[^\x00-\xff]+/
20.email地址 /^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$/
或者 /w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*/
21.url地址 /^[a-zA-z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$/
或者 /http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?/
22.匹配中文字符的正则 /[u4e00-u9fa5]/
23.匹配双字节字符(包括汉字在内) /[^x00-xff]/
应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
String.prototype.len=function()
{
return this.replace([^x00-xff]/g,”aa”).length;
}
24.匹配空行的正则 /n[s| ]*r/
25.匹配HTML标记的正则 /<(.*)>.*</1>|<(.*) />/
26.匹配首尾空格的正则 /(^s*)|(s*$)/
应用:javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现,如下:
String.prototype.trim = function()
{
return this.replace(/(^s*)|(s*$)/g, “”);
}
27.匹配IP地址的正则 /(d+).(d+).(d+).(d+)/
应用:利用正则表达式匹配IP地址,并将IP地址转换成对应数值的Javascript程序:
function IP2V(ip)
{
re=/(d+).(d+).(d+).(d+)/g;
if(re.test(ip)){
return RegExp.$1*Math.pow(255,3))+
RegExp.$2*Math.pow(255,2))+
RegExp.$3*255+RegExp.$4*1;
}
else
{
throw new Error(“Not a valid IP address!”);
}
}
其实直接用split函数来分解可能更简单,程序如下:
var ip=”10.100.20.168″;
ip=ip.split(“.”);
alert(“IP值是:”+(ip[0]*255*255*255+ip[1]*255*255+ip[2]*255+ip[3]*1));
28.去除字串中重复的字符的javascript程序
var s=”abacabefgeeii”;
var s1=s.replace(/(.).*1/g,”$1″);
var re=new RegExp(“["+s1+"]“,”g”);
var s2=s.replace(re,”");
alert(s1+s2); //结果为:abcefgi
/*使用后向引用取出包括重复的字符,再以重复的字符建立第二个表达式,取到不重复的字符,
两者串连。这个方法对于字符顺序有要求的字符串可能不适用。
*/
29.用正则表达式从URL地址中提取文件名的javascript程序
s=”http://www.google.com/page1.htm“;
s=s.replace(/(.*/)
{0,}([^.]+).*/ig,”$2″);
alert(s); //结果为page1
30.限制表单文本框输入内容
只能输入中文:
onkeyup=”value=value.replace(/[^u4E00-u9FA5]/g,”)”
onbeforepaste=”clipboardData.setData(‘text’,
clipboardData.getData(‘text’).replace(/[^u4E00-u9FA5]/g,”))”
只能输入全角字符:
onkeyup=”value=value.replace(/[^uFF00-uFFFF]/g,”)”
onbeforepaste=”clipboardData.setData(‘text’,
clipboardData.getData(‘text’).replace(/[^uFF00-uFFFF]/g,”))”
只能输入数字:
onkeyup=”value=value.replace(/[^d]/g,”)”
onbeforepaste=”clipboardData.setData(‘text’,
clipboardData.getData(‘text’).replace(/[^d]/g,”))”
只能输入数字和英文:
onkeyup=”value=value.replace(/[W]/g,”)”
onbeforepaste=”clipboardData.setData(‘text’,
clipboardData.getData(‘text’).replace(/[^d]/g,”))”
31.验证文件名由字母,数字,下滑线组成 /^((\w+)(\.
{1})(\w+))$/
32.匹配日期(1900-1999)
/^19\d
{2}-((0[1-9])|(1[0-2]))-((0[1-9])|([1-2][0-9])|(3([0|1])))$/
33.匹配日期(2000-2999)
/^20\d
{2}-((0[1-9])|(1[0-2]))-((0[1-9])|([1-2][0-9])|(3([0|1])))$/
34.匹配日期时间
/^(1|2\d
{3}-((0[1-9])|(1[0-2]))-((0[1-9])|([1-2][0-9])|(3([0|1]))))( (\d{2}):(\d{2}):(\d{2}))?$/

分享到:
评论

相关推荐

    jQuery validator addMethod 根据不同情况显示不同错误信息

    本文将深入探讨如何使用`jQuery validator addMethod`来根据不同的情况显示不同的错误信息。 `jQuery validator addMethod`是jQuery Validation Plugin中的一个关键功能,允许开发者自定义验证方法。当你发现内置的...

    详解jquery validate实现表单验证 (正则表达式)

    本文将深入讲解如何使用jQuery Validate结合正则表达式实现高效且灵活的表单验证。 首先,`validate()`是jQuery Validate插件的核心方法,用于初始化验证行为。你可以设置`rule`来定义验证规则,如`required`表示...

    jquery.validate.js jquery表单验证

    这可以通过 `$.validator.addMethod()` 函数实现,它可以接受三个参数:规则名、验证函数和错误消息。 6. **错误消息国际化**:对于中文环境,`jQuery Validate` 支持错误消息的本地化,这意味着可以设置不同的错误...

    Jquery Validate 正则表达式实用验证代码大全

    以下为引用内容: 代码如下:jQuery.validator.addMethod(“mobile”, function(value, element) { var length = value.length; var mobile = /^(((13[0-9]{1})|(15[0-9]{1}))+\d{8})$/ return this.optional(element...

    很强大jquery表单验证插件jquery.validate.js api.pdf

    如果内置的验证规则不能满足需求,`jQuery Validate`提供了`addMethod`函数,允许开发者添加自己的验证方法。例如,示例代码中的`iszipcode`方法就是一个自定义的邮政编码验证规则。 5. **便捷的错误消息显示**: ...

    jquery.validate 扩展身份证校验方法

    这里使用`addMethod`函数向`jQuery.validator`添加了一个名为`idCardNo`的新方法,该方法接受两个参数:`value`(待验证的值)和`element`(待验证的DOM元素)。 #### 内部验证逻辑 内部验证逻辑主要分为以下几个...

    jquery input字符串验证(手机号码验证、字母数字验证) 带示列

    本教程将详细讲解如何使用jQuery进行字符串验证,特别是手机号码验证和字母数字验证,以及涉及的正则表达式知识。 一、jQuery基础 jQuery是一个轻量级的JavaScript库,它简化了JavaScript的DOM操作、事件处理和动画...

    Jquery常用正在表达式验证

    其中,正则表达式验证是jQuery实现表单数据有效性检查的重要手段。本篇文章将详细探讨jQuery中的正则表达式验证,以及如何在实际项目中应用这些验证规则。 一、jQuery验证基础 jQuery提供了多种方法进行表单验证,...

    JS中常用的正则表达式

    以下收录一些我经常用到的正则表达式,因为工作场景中用到正则的地方几乎都跟validate插件的验证有关系,所以以下正则也是$.validator.addMethod() 的拓展: validate: http://jqueryvalidation.org/ 电话验证 /** ...

    jquery.validate使用攻略 第五步 正则验证

    在本文中,我们将深入探讨如何使用 jQuery Validate 插件中的正则表达式进行数据验证。jQuery Validate 是一个非常流行的插件,它可以帮助开发者快速实现表单验证功能,从而提高用户体验和减少服务器端的压力。本文...

    jq.validate文件 new

    5. 自定义验证:如果内置规则无法满足需求,可以通过`.addMethod()`创建新的验证方法。 四、正则表达式验证 jq.validate中内置了一些常用的正则表达式,如`email`、`url`、`number`等。开发者可以根据需要选择合适...

    jquery validate包

    在这个例子中,我们创建了一个新的验证方法`phone`,并用正则表达式检查电话号码的格式。 最后,jQuery Validate还提供了丰富的事件和API接口,如`valid`, `invalid`, `errorPlacement`等,使得在验证过程中实现更...

    正则验证小数点后面只能有两位数的方法

    5. **jQuery Validate插件**:该插件提供了一个非常方便的验证规则添加方法`jQuery.validator.addMethod`。例如,以下的代码定义了两个规则"lrunlv"和"decimals": ``` jQuery.validator.addMethod("lrunlv", ...

    jquery.validate表单验证插件使用详解

    jQuery Validate插件简化了在HTML表单中添加验证规则的过程,无需编写复杂的正则表达式,使得前端开发更加便捷。 首先,我们需要引入jQuery库以及jQuery Validate插件的JavaScript文件。在HTML文档中,确保包含以下...

    基于Bootstrap+jQuery.validate实现表单验证

    开发者可以使用jQuery.validator.addMethod方法定义一个新的验证规则,然后在表单的rules对象中调用这个自定义的验证方法,并配置相应的错误提示信息。这样的做法既保证了验证的灵活性,也保证了用户输入的有效性。 ...

    jQuery validate插件实现ajax验证重复的2种方法

    在代码中,通过`addMethod`方法添加了两个新的验证规则:“phonecheck”和“phonesame”。这两个方法分别用于检查电话号码格式和检查电话号码是否已经在数据库中存在。 `phonecheck`规则使用正则表达式来校验电话...

    jQuery.validationEngine 表单验证中文版

    通过`addMethod`函数,可以创建新的验证规则,满足特定业务需求。 总结来说,jQuery.validationEngine是一个功能强大且灵活的前端表单验证工具,能够有效帮助开发者实现数据的实时校验,提升用户交互体验,同时也...

    JQuery扩展插件Validate 5添加自定义验证方法

    示例如下: 代码如下: [removed] jQuery.validator.addMethod(“regex”, //addMethod第1个参数:方法名称 function(value, element, params) { //addMethod第2个参数:验证方法,参数(被验证元素的值,被验证元素,...

Global site tag (gtag.js) - Google Analytics