【www.gdgbn.com--jquery】


/// jquery-1.4.1-vsdoc.js" />
//验证方法 v1.0,创建于2010-12-9 完成2010-12-16 mr.x 制
//修改2010-12-10、2010-12-12、2010-12-15、2010-12-16添入信息提示动画效果
//支持 type=text type=checkbox type=radio select 标签验证
//vld="***"必填 格式验证
//vld="n***"选填 格式验证
//err="***"错误显示内容
//super="y"用追加提示信息,要用y以外字母得修改同级一组验证,同级一组的标签可以在第一个标签进行super="y"属性标识,其它不用
//len="***"长度限制,用于textarea标签
//
$(function () {
//正则匿名对象
var strregex = {};
//错误信息匿名对象
var strerror = {};
//正确信息匿名对象
var strright = {};
/** 参数配置 start **/
//非空
strregex.nonull = /[^s]+/;
strerror.nonull = "请填写内容,如123、中国!";
//邮箱
strregex.email = /^([a-za-z0-9_-])+@([a-za-z0-9_-])+((.[a-za-z0-9_-]{2,3}){1,2})$/;
strerror.email = "请核对邮箱格式,如china@163.com!";
//网址
strregex.url = /^http://[a-za-z0-9]+.[a-za-z0-9]+[/=?%-&_~`@[]":+!]*([^""])*$/;
strerror.url = "请核对网址格式,如http://www.111cn.net!";
//账号
strregex.an = /^([a-za-z0-9]|[_]){6,16}$/;
strerror.an = "请核对账号格式,如china_56!";
//数字
strregex.math = /d+$/;
strerror.math = "请核对数字格式,如1234!";
//年龄
strregex.age = /^d{2}$/;
strerror.age = "请核对年龄格式,10~99岁之间!";
//邮编
strregex.post = /^[1-9]d{5}$/;
strerror.post = "请核对邮编格式,如150001!";
//电话
strregex.phone = /^((d{11})|((d{7,8})|(d{4}|d{3})-(d{7,8})|(d{4}|d{3})-(d{7,8})-(d{4}|d{3}|d{2}|d{1})|(d{7,8})-(d{4}|d{3}|d{2}|d{1})))$/;
strerror.phone = "请核对电话格式,如15546503251!";
//身份证
strregex.card = /^(([1-9]d{5}[1-9]d{3}((0d)|(1[0-2]))(([0|1|2]d)|3[0-1])((d{4})|d{3}[x,x]))|([1-9]d{5}[1-9]d{1}((0d)|(1[0-2]))(([0|1|2]d)|3[0-1])(d{3})))$/;
strerror.card = "请核对身份证格式,如230103190001010000!";
//金钱
strregex.price = /^([1-9]d*|0)(.d+)?$/;
strerror.price = "请核对金钱格式,如99.98!";
//日期
strregex.date = /((^((1[8-9]d{2})|([2-9]d{3}))([-/._])(10|12|0?[13578])([-/._])(3[01]|[12][0-9]|0?[1-9])$)|(^((1[8-9]d{2})|([2-9]d{3}))([-/._])(11|0?[469])([-/._])(30|[12][0-9]|0?[1-9])$)|(^((1[8-9]d{2})|([2-9]d{3}))([-/._])(0?2)([-/._])(2[0-8]|1[0-9]|0?[1-9])$)|(^([2468][048]00)([-/._])(0?2)([-/._])(29)$)|(^([3579][26]00)([-/._])(0?2)([-/._])(29)$)|(^([1][89][0][48])([-/._])(0?2)([-/._])(29)$)|(^([2-9][0-9][0][48])([-/._])(0?2)([-/._])(29)$)|(^([1][89][2468][048])([-/._])(0?2)([-/._])(29)$)|(^([2-9][0-9][2468][048])([-/._])(0?2)([-/._])(29)$)|(^([1][89][13579][26])([-/._])(0?2)([-/._])(29)$)|(^([2-9][0-9][13579][26])([-/._])(0?2)([-/._])(29)$))/;
strerror.date = "请核对日期格式,如1999.9.9、1999-9-9、1999.09.09!";
//时间
strregex.time = /^([0-9]|[0-1][0-9]|[2][0-3])(:|:)([0-5][0-9])$/;
strerror.time = "请核对时间格式,如23:59!";
strerror.length = "请核对输入信息长度,长度小于";
strright.info = "格式正确!"; //可以设置为空
//下拉框
strregex.ddl = "请选择";
strerror.ddl = "请选择选项";
//单个checkbox复选框
strregex.check = "请选择";
strerror.check = "请选择选项";
//单个radio复选框
strregex.radio = "请选择";
strerror.radio = "请选择选项";
//同级一组checkbox复选框
strregex.checkgroup = "请选择";
strerror.checkgroup = "请选择选项";
//同级一组radio复选框
strregex.radiogroup = "请选择";
strerror.radiogroup = "请选择选项";
//在标签后面追加信息
var spanerror = "";
var spanok = "";
/** 参数配置 end **/
/** main **/
//文件目录,回返最顶级目录 ../
function filepath() {
var file = "";
var path = window.location.pathname.split("/");
$(path).each(function () {
file = "../" + file;
});
return file;
}
//页验证自检
$("#form1 [vld]").blur(function () {
regexgether($(this));
});
//验证处理集合
function regexgether($ctrl) {
switch ($ctrl.attr("vld")) {
case "nonull":
regexnull($ctrl);
break;
case "age":
regexinputtextall($ctrl, strregex.age, strerror.age);
break;
case "nage":
regexinputtextonly($ctrl, strregex.age, strerror.age);
break;
case "date":
regexinputtextall($ctrl, strregex.date, strerror.date);
break;
case "ndate":
regexinputtextonly($ctrl, strregex.date, strerror.date);
break;
case "price":
regexinputtextall($ctrl, strregex.price, strerror.price);
break;
case "nprice":
regexinputtextonly($ctrl, strregex.price, strerror.price);
break;
case "email":
regexinputtextall($ctrl, strregex.email, strerror.email);
break;
case "nemail":
regexinputtextonly($ctrl, strregex.email, strerror.email);
break;
case "post":
regexinputtextall($ctrl, strregex.post, strerror.post);
break;
case "npost":
regexinputtextonly($ctrl, strregex.post, strerror.post);
break;
case "card":
regexinputtextall($ctrl, strregex.card, strerror.card);
break;
case "ncard":
regexinputtextonly($ctrl, strregex.card, strerror.card);
break;
case "time":
regexinputtextall($ctrl, strregex.time, strerror.time);
break;
case "ntime":
regexinputtextonly($ctrl, strregex.time, strerror.time);
break;
case "math":
regexinputtextall($ctrl, strregex.math, strerror.math);
break;
case "nmath":
regexinputtextonly($ctrl, strregex.math, strerror.math);
break;
case "url":
regexinputtextall($ctrl, strregex.url, strerror.url);
break;
case "nurl":
regexinputtextonly($ctrl, strregex.url, strerror.url);
break;
case "an":
regexinputtextall($ctrl, strregex.an, strerror.an);
break;
case "nan":
regexinputtextonly($ctrl, strregex.an, strerror.an);
break;
case "phone":
regexinputtextall($ctrl, strregex.phone, strerror.phone);
break;
case "nphone":
regexinputtextonly($ctrl, strregex.phone, strerror.phone);
break;
case "ddl":
regexselect($ctrl);
break;
case "check":
regexinputcheckboxradioonly($ctrl, strerror.check);
break;
case "radio":
regexinputcheckboxradioonly($ctrl, strerror.radio);
break;
case "checkgroup":
regexinputcheckboxradioall($ctrl, strerror.checkgroup);
break;
case "radiogroup":
regexinputcheckboxradioall($ctrl, strerror.radiogroup);
break;
}
}
//标签内容空验证
function regexnull($ctrl) {
if (strregex.nonull.test($ctrl.val())) {
return regexlen($ctrl);
}
else {
error($ctrl, strerror.nonull);
return false;
}
}
//验证多个同级一组input(type=radio)标签 或 input(type=checkbox)标签
function regexinputcheckboxradioall($ctrl, error) {
if ($ctrl.parent().children(":checked").length == 0) {
if ($ctrl.parent().children().attr("super")) {
//同级标签中可能会有多个[super="y"]存在,只取一个,用return false;控制,执行一次就从循环体中跳出
$ctrl.parent().children("[super="y"]").each(function () {
error($(this), error);
return false;
});
}
else {
//同级一组标签一起报错
$ctrl.parent().children("[type="" + $ctrl.attr("type") + ""]").each(function () {
error($(this), error);
});
}
return false;
}
else {
if ($ctrl.parent().children().attr("super")) {
$ctrl.parent().children("[super="y"]").each(function () {
ok($(this));
return false;
});
}
else {
$ctrl.parent().children().each(function () {
ok($(this));
});
}
return true;
}
}
//验证单个input(type=radio)标签 或 input(type=checkbox)标签
function regexinputcheckboxradioonly($ctrl, error) {
if (!$ctrl.attr("checked")) {
error($ctrl, error);
return false;
}
else {
ok($ctrl);
return true;
}
}
//select标签,选项验证
function regexselect($ctrl) {
if ($ctrl.val() == strregex.ddl) {
error($ctrl, strerror.ddl);
return false;
}
else {
ok($ctrl);
return true;
}
}
//标签允许为空内容格式验证,type=text标签验证
function regexinputtextonly($ctrl, regex, error) {
//先验证标签是否为空
if (strregex.nonull.test($ctrl.val())) {
return regexotherformat($ctrl, regex, error);
}
else {
ok($ctrl);
return true;
}
}
//标签不允许为空内容格式验证,type=text标签验证
function regexinputtextall($ctrl, regex, error) {
//先验证标签是否为空
if (strregex.nonull.test($ctrl.val())) {
return regexotherformat($ctrl, regex, error);
}
else {
error($ctrl, error);
return false;
}
}
//标签内容格式验证
function regexotherformat($ctrl, regex, error) {
if (regex.test($ctrl.val())) {
return regexlen($ctrl);
}
else {
error($ctrl, error);
return false;
}
}
//textarea标签长度验证
function regexlen($ctrl) {
//标签中是否有len属性
if ($ctrl.attr("len")) {
var error = strerror.length + $ctrl.attr("len") + "字!";
if (parseint($ctrl.val().length) > parseint($ctrl.attr("len"))) {
error($ctrl, error);
return false;
}
}
ok($ctrl);
return true;
}
//格式验证错误显示
function error($ctrl, error) {
//标签中有err属性,根据属性内容填入title中
if ($ctrl.attr("err")) {
error = $ctrl.attr("err");
}
if ($ctrl.attr("super")) {
//具有super属性标签追加span
$ctrl.parent().find("span").remove();
$ctrl.parent().append(spanerror);
$ctrl.parent().find("span").append(error);
$ctrl.parent().find("span").fadeto("slow", 0.66);
}
else {
//追加到title属性中
$ctrl.attr("title", error);
$ctrl.addclass("error");
}
}
//格式验证无误,清除错误样式
function ok($ctrl) {
//去除可以存在的错误样式
if ($ctrl.attr("super")) {
$ctrl.parent().find("span").remove();
}
else {
$ctrl.removeclass("error");
}
if ($.trim($ctrl.val()).length > 0) {
var right = strright.info;
//检查标签中是否有rig属性
if ($ctrl.attr("rig")) {
right = $ctrl.attr("rig");
}
//添加正确提示信息
if ($ctrl.attr("super")) {
$ctrl.parent().append(spanok);
$ctrl.parent().find("span").append(right);
$ctrl.parent().find("span").fadeto("slow",0.99).fadeto("slow",0.99).fadeto("slow",0);
}
else {
$ctrl.attr("title", right);
}
}
}
//提交自检
$("#vldbtn").click(function () {
$("#form1 [vld]").each(function () {
regexgether($(this));
});
//检查标签中样式是否有error
if ($("#form1 [vld][class="error"]").length > 0) {
return false;
}
else {
return true;
}
});
});

本文来源:http://www.gdgbn.com/wangyezhizuo/28600/