Javascript 验证Validator.js 使用全解(转载)

文件Validator.js

Validator={
Require : /.+/,
Email : /^\w+([-+.]\w+)*@\w+([-.]\\w+)*\.\w+([-.]\w+)*$/,
Phone : /^((\(\d{3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}$/,
Mobile : /^((\(\d{3}\))|(\d{3}\-))?13\d{9}$/,
Url : /^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\’:+!]*([^<>\"\"])*$/,
IdCard : /^\d{15}(\d{2}[A-Za-z0-9])?$/,
Currency : /^\d+(\.\d+)?$/,
Number : /^\d+$/,
Zip : /^[1-9]\d{5}$/,
QQ : /^[1-9]\d{4,8}$/,
Integer : /^[-\+]?\d+$/,
Do le : /^[-\+]?\d+(\.\d+)?$/,
English : /^[A-Za-z]+$/,
Chinese : /^[\Α-\¥]+$/,
UnSafe : /^(([A-Z]*|[a-z]*|\d*|[-_\~!@#\$%\^&\*\.\(\)\[\]\{\}<>\?\\\/\’\"]*)|.{0,5})$|\s/,
IsSafe : function(str){return !this.UnSafe.test(str);},
SafeString : "this.IsSafe(val)",
Limit : "this.limit(val.length,getAttribute(’min’), getAttribute(’max’))",
LimitB : "this.limit(this.LenB(val), getAttribute(’min’), getAttribute(’max’))",
Date : "this.IsDate(val, getAttribute(’min’), getAttribute(’format’))",
Repeat : "val == document.getElementsByName(getAttribute(’to’))[0].val",
Range : "getAttribute(’min’) < val && val < getAttribute(’max’)",
Compare : "this.compare(val,getAttribute(’operator’),getAttribute(’to’))",
Custom : "this.Exec(val, getAttribute(’regexp’))",
Group : "this.MustChecked(getAttribute(’name’), getAttribute(’min’), getAttribute(’max’))",
ErrorItem : [document.forms[0]],
ErrorMessage : ["The cause of failure as below : \t\t\t\t"],
Validate : function(theform, mode){
var obj = theform || event.srcElement;
var count = obj.elements.length;
this.ErrorMessage.length = 1;
this.ErrorItem.length = 1;
this.ErrorItem[0] = obj;
for(var i=0;i with(obj.elements[i]){
var _dataType = getAttribute("dataType";
if(typeof(_dataType) == "object" || typeof(this[_dataType]) == "undefined" contin;
this.ClearState(obj.elements[i]);
if(getAttribute("require"== "false" && val == ""contin;
switch(_dataType){
case "Date" :
case "Repeat" :
case "Range" :
case "Compare" :
case "Custom" :
case "Group" :
case "Limit" :
case "LimitB" :
case "SafeString" :
if(!eval(this[_dataType])){
this.AddError(i, getAttribute("msg");
}
break;
default :
if(!this[_dataType].test(val)){
this.AddError(i, getAttribute("msg");
}
break;
}
}
}
if(this.ErrorMessage.length > 1){
mode = mode || 1;
var errCount = this.ErrorItem.length;
switch(mode){
case 2 :
for(var i=1;i this.ErrorItem[i].style.color = "red";
case 1 :
alert(this.ErrorMessage.join("\n");
this.ErrorItem[1].focus();
break;
case 3 :
for(var i=1;i try{
var span = document.createElement("SPAN";
span.id = "__ErrorMessagePanel";
span.style.color = "red";
this.ErrorItem[i].parentNode.appendChild(span);
span.innerHTML = this.ErrorMessage[i].replace(/\d+:/,"*";
}
catch(e){alert(e.description);}
}
this.ErrorItem[1].focus();
break;
default :
alert(this.ErrorMessage.join("\n");
break;
}
return false;
}
return tr;
},
limit : function(len,min, max){
min = min || 0;
max = max || Number.MAX_VAL;
return min <= len && len <= max;
},
LenB : function(str){
return str.replace(/[^\x00-\xff]/g,"**".length;
},
ClearState : function(elem){
with(elem){
if(style.color == "red"
style.color = "";
var lastNode = parentNode.childNodes[parentNode.childNodes.length-1];
if(lastNode.id == "__ErrorMessagePanel"
parentNode.removeChild(lastNode);
}
},
AddError : function(index, str){
this.ErrorItem[this.ErrorItem.length] = this.ErrorItem[0].elements[index];
this.ErrorMessage[this.ErrorMessage.length] = this.ErrorMessage.length + ":" + str;
},
Exec : function(op, reg){
return new RegExp(reg,"g".test(op);
},
compare : function(op1,operator,op2){
switch (operator) {
case "NotEq l":
return (op1 != op2);
case "GreaterThan":
return (op1 > op2);
case "GreaterThanEq l":
return (op1 >= op2);
case "LessThan":
return (op1 < op2);
case "LessThanEq l":
return (op1 <= op2);
default:
return (op1 == op2);
}
},
MustChecked : function(name, min, max){
var groups = document.getElementsByName(name);
var hasChecked = 0;
min = min || 1;
max = max || groups.length;
for(var i=groups.length-1;i>=0;i--)
if(groups[i].checked) hasChecked++;
return min <= hasChecked && hasChecked <= max;
},
IsDate : function(op, formatString){
formatString = formatString || "ymd";
var m, year, month, day;
switch(formatString){
case "ymd" :
m = op.match(new RegExp("^\\s*((\\d{4})|(\\d{2}))([-./])(\\d{1,2})\\4(\\d{1,2})\\s*$");
if(m == null ) return false;
day = m[6];
month = m[5]--;
year = (m[2].length == 4) ? m[2] : GetFullYear(parseInt(m[3], 10));
break;
case "dmy" :
m = op.match(new RegExp("^\\s*(\\d{1,2})([-./])(\\d{1,2})\\2((\\d{4})|(\\d{2}))\\s*$");
if(m == null ) return false;
day = m[1];
month = m[3]--;
year = (m[5].length == 4) ? m[5] : GetFullYear(parseInt(m[6], 10));
break;
default :
break;
}
var date = new Date(year, month, day);
return (typeof(date) == "object" && year == date.getFullYear() && month == date.getMonth() && day == date.getDate());
function GetFullYear(y){return ((y<30 ? "20" : "19"+ y)|0;}
}
}


js代码

使用:

语法dataType="Require|Chinese|English|Number|Integer|Do le|Email|Url|Phone|Mobile|Currency|Zip|IdCard|QQ|Date|SafeString|Repeat|Compare|Range|Limit|LimitB|Group|Custom"
类型字符串。必选。
说明:用于设定表单项的输入数据验证类型。
选值说明
可选值 验证功能
Require 必填项
Chinese 中文
English 英文

Number
数字
Integer
整数
Do le
实数
Email
Email地址格式
Url
基于HTTP协议的网址格式
Phone
电话号码格式
Mobile
手机号码格式
Currency 货币格式
Zip
邮政编码
IdCard
身份证号码
QQ
QQ号码
Date 日期
SafeString 安全密码
Repeat
重复输入
Compare
关系比较
Range
输入范围
Limit
限制输入长度
LimitB
限制输入的字节长度
Group 验证单/多选按钮组
Custom 自定义正则表达式验证
语法max="int"
类型:字符串。在dataType属性值为Range时必选,为Group且待验证项是多选按钮组时可选(此时默认值为1),为为Limit/LimitB时可选(此时默认值为1.7976931348623157e+308,即Number.MAX_VAL的值)。
说明:当daType属性值为Range时,用于判断输入是否在minmax的属性值间;当dataType属性值为Group,且待验证项是多选按钮组时,用于设定多选按钮组的选中个数,判断选中个数是否在[min,max]区间;当daType属性值为Limit时,用于验证输入的字符数是否在[min,max]区间;当daType属性值为LimitB时,用于验证输入字符的字节数是否在[min,max]区间。
语法min="int"
类型:字符串。在dataType属性值为Range时必选,为Group且待验证项是多选按钮组时可选(此时默认值为1),为为Limit/LimitB时可选(此时默认值为0)。
说明:当daType属性值为Range时,用于判断输入是否在minmax的属性值间;当dataType属性值为Group,且待验证项是多选按钮组时,用于设定多选按钮组的选中个数,判断选中个数是否在[min,max]区间;当daType属性值为Limit时,用于验证输入的字符数是否在[min,max]区间;当daType属性值为LimitB时,用于验证输入字符的字节数是否在[min,max]区间。
语法msg="string"
类型:字符串。必选。
说明:在验证失败时要提示的出错信息。
语法operator="NotEq l|GreaterThan|GreaterThanEq l|LessThan|LessThanEq l|Eq l"
类型:字符串。在dataType属性值为Compare时可选(默认值为Eq l)。
说明:参考to属性。
各选值所对应的关系操作符
可选值 意义说明
NotEq l
不等于 !=
GreaterThan 大于 >
GreaterThanEq l
大于等于 >=
LessThan 小于 <
LessThanEq l 小于等于 <=
Eq l 等于 =
语法require="tr|false"
类型:字符串。可选。
说明:用于设定表单项的验证方式。当值为false时表单项不是必填项,但当有填写时,仍然要执行dataType属性所设定的验证方法,值为tr或任何非false字符时可省略此属性。
语法to="sting|int"
类型:字符串。当dataType值为RepeatCompare时必选。
说明:当dataType值为Repeat时,to的值为某表单项的name属性值,用于设定当前表单项的值是否与目标表单项的值一致;当dataType的值为Compare时,to的选值类型为实数,用于判断当前表单项的输入与to的值是否符合operator属性值所指定的关系。
语法format="ymd|dmy"
类型:字符串。在dataType属性值为Date时可选(默认值为ymd)。
说明:用于验证输入是否为符合format属性值所指定格式的日期。
符合规则的输入示例 :2004-11-232004/11/2304.11.2323-11-2004
注意:当输入的年份为2位时,如果数值小于30,将使年份看作处于21世纪,否则为20世纪。
语法regexp="object"
类型:字符串。在dataType属性值为Custom时必选。
说明:用于验证输入是否符合regexp属性所指定的正则表达式。

示例:

引用:http://www.phpchina.com/?8133/action_viewspace_itemid_3214.html

********************************************************************************************

使用帮助(FAQs)

********************************************************************************************

-------------------------------------------------------------------------------------------

验证表单

在表单中加上ons mit事件,触发调用Validaotor的Validate方法,代码示例:


... ...

Validate方法有两个可选参数,第一个为表单对象,如果是写在表单的ons mit事件中,可以用this指代当前表单,默认值为事件源对象;第二个参数为错误提示模式,可选值为1,2和3,默认值为1。省略第二个参数时相当于使用Validate(objform,1),省略第一个参数时相当于 Validate(this,1)。注意,不可以省略第一个参数而只写第二个参数,Validate(,2)是错误的用法。

--------------------------------------------------------------------------------------------

验证输入是否Email地址

代码示例:





Validator的必要属性是dataType和msg(区分大小写),然后根据dataType值的不同,会引发出不同的属性。因为程序中已经集成 Email地址格式的正则,所以可以直接用dateType="Email"进行验证,如果对Email地址的格式有不同的限制,可以用自定义的正则来验证(参考第二段代码)。

--------------------------------------------------------------------------------------------

验证下拉菜单是否选中

代码示例:

注意,对于IE,在option中没写val属性时IE的解释引擎将自动设置其值为空,而Firefox时将自动设置其值为text属性址。例如,在示例代码中如果第一个option不写val属性,IE中将得到val为空,而Firefox为"选择您所用的操作系统"。

--------------------------------------------------------------------------------------------

验证是否选中单选按钮组中的一个

代码示例:
广东
陕西
浙江
江西
对于单/多选按钮组的验证,dataType属性都为Group,然后只需在按钮组的最后一个写上dataType和msg属性。
注意,要成为单/多选按钮组,它们必须具有相同的name属性值。

--------------------------------------------------------------------------------------------

限制多选按钮组的选中个数

代码示例:
运动
上网
听音乐
看书
要限制多选按钮组的选中个数,必须设置min和max属性。min属性用于设定选中个数的下限,max为上限,默认时min为1,max为多选按钮组的个数。

--------------------------------------------------------------------------------------------

完整示例:运行 demo.html



//文件 demo.html

//该文件只是举例说明如何使用 Validator.js文件


http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd
">








表单验证类 Validator v1.05













































































身份证号:
真实姓名:
ID:
英文名:
主页:
密码:
重复:
信箱:
信箱:
QQ:
身份证:
年龄:
年龄1:
电话:
手机:
生日:
邮政编码:
邮政编码:
操作系统:
所在省份:广东陕西浙江江西
爱好:运动上网听音乐看书
自我介绍:
自传:
相片上传:

你可能感兴趣的:(Javascript 验证Validator.js 使用全解(转载))