validationEngine中文版 — jquery强大的表单验证插件(做了些小修改)
2011-07-11 17:18
579 查看
中文汉化版,官方只有英文的。修改了部分验证规则。
这个插件支持大部分的浏览器,但由于有使用到了css3的阴影和圆角样式,所以在IE浏览器下无法看到圆角和阴影效果(万恶的IE)。
官方下载地址:http://www.position-absolute.com/articles/jquery-form-validator-because-form-validation-is-a-mess/
普通验证的例子:http://www.position-relative.net/creation/formValidator/
ajax验证的例子:http://www.position-relative.net/creation/formValidator/demoSubmit.html
<link type="text/css" rel="Stylesheet" href="css/template.css" />
<link type="text/css" rel="Stylesheet" href="css/css.css" />
<script src="js/jquery.js" type="text/javascript"></script>
<script src="js/jquery.validationEngine-en.js" type="text/javascript"></script>
<script src="js/jquery.validationEngine.js" type="text/javascript"></script>
jquery.validationEngine-en.js是语言文件,所有的提示都在这个文件找的到,可以很方便的转成其他语言,同时你也可以在这个文件内定制属于自己的验证规则。
$("#formID").validationEngine()
})
验证规则是写在表单元素的class属性内。比如下面:
<input value="" class="validate[required,custom[noSpecialCaracters],length[0,20],ajax[ajaxUser]]" type="text" name="user" id="user" />
验证规则非常多样,基本上包含了所有的数据类型的验证。
所有的验证规则写在validate[]内,有多种验证,用逗号隔开,这里简要说明下常用的验证规则。
required:值不可以为空
length[0,100] :文字允许长度
minSize:最小字符长度
maxSize:最大字符长度
min:最小值
max:最大值
equals[fieldID] :匹配其他的表单元素的值,fieldID就是其他表单元素的id,这个主要用于再次确认密码
telephone :数据格式要求符合电话格式
email : 数据格式要求符合email 格式
onlyNumber :只允许输入数字
noSpecialCaracters :不允许出现特殊字符
onlyLetter : 只能是字母
date :必须符合日期格式YYYY-MM-DD
inlineValidation: false,
success : false,
failure : function() { callFailFunction() }
})
validationEventTriggers:"keyup blur", //will validate on keyup and blur
success : false,
failure : function() { callFailFunction() }
})
validationEventTriggers属性就是修改绑定事件,上面是增加了个keyup,也就是键盘按键起来就触发验证。
promptPosition: "topRight", // OPENNING BOX POSITION, IMPLEMENTED: topLeft, topRight, bottomLeft, centerRight, bottomRight
success : false,
failure : function() {
})
promptPosition就是控制位置,有5种模式:topLeft, topRight, bottomLeft, centerRight, bottomRight
错误显示方式
$("#formID").validationEngine({
promptPosition: "topRight", // OPENNING BOX POSITION, IMPLEMENTED: topLeft, topRight, bottomLeft, centerRight, bottomRight
showTypes:2,//默认是1
success : false,
failure : function() {
})
ajaxSubmit: true,
ajaxSubmitFile: "ajaxSubmit.php",
ajaxSubmitMessage: "Thank you, we received your inscription!",
ajaxSubmitExtraData: "securityCode=38709238423&name=john",
success : false,
failure : function() {}
})
这几个参数很好理解。
ajaxSubmit: true, 提交表单使用ajax提交
ajaxSubmitFile: “ajaxSubmit.php”, 后台脚本
ajaxSubmitMessage 成功后显示的信息
ajaxSubmitExtraData 参数
这里需要对后台脚本返回的数据进行下说明:
返回的数据格式是json。
出现一个错误,产生一个数组,如下:
$arrayError[0][0] = "#email"; // FIELDID
$arrayError[0][1] = "Your email do not match.. whatever it need to match"; // TEXT ERROR
$arrayError[0][2] = "error"; // BOX COLOR
源代码
jquery.validationEngine-en.js
jquery.validationEngine.js
CSS.CSS
View Code
这个插件支持大部分的浏览器,但由于有使用到了css3的阴影和圆角样式,所以在IE浏览器下无法看到圆角和阴影效果(万恶的IE)。
官方下载地址:http://www.position-absolute.com/articles/jquery-form-validator-because-form-validation-is-a-mess/
普通验证的例子:http://www.position-relative.net/creation/formValidator/
ajax验证的例子:http://www.position-relative.net/creation/formValidator/demoSubmit.html
一:简单说明下使用教程:
引入jquery和插件js、css
<link rel="stylesheet" href="css/validationEngine.jquery.css" type="text/css" media="screen" charset="utf-8" /><link type="text/css" rel="Stylesheet" href="css/template.css" />
<link type="text/css" rel="Stylesheet" href="css/css.css" />
<script src="js/jquery.js" type="text/javascript"></script>
<script src="js/jquery.validationEngine-en.js" type="text/javascript"></script>
<script src="js/jquery.validationEngine.js" type="text/javascript"></script>
jquery.validationEngine-en.js是语言文件,所有的提示都在这个文件找的到,可以很方便的转成其他语言,同时你也可以在这个文件内定制属于自己的验证规则。
初始化插件
$(document).ready(function() {$("#formID").validationEngine()
})
验证规则是写在表单元素的class属性内。比如下面:
<input value="" class="validate[required,custom[noSpecialCaracters],length[0,20],ajax[ajaxUser]]" type="text" name="user" id="user" />
验证规则非常多样,基本上包含了所有的数据类型的验证。
所有的验证规则写在validate[]内,有多种验证,用逗号隔开,这里简要说明下常用的验证规则。
required:值不可以为空
length[0,100] :文字允许长度
minSize:最小字符长度
maxSize:最大字符长度
min:最小值
max:最大值
equals[fieldID] :匹配其他的表单元素的值,fieldID就是其他表单元素的id,这个主要用于再次确认密码
telephone :数据格式要求符合电话格式
email : 数据格式要求符合email 格式
onlyNumber :只允许输入数字
noSpecialCaracters :不允许出现特殊字符
onlyLetter : 只能是字母
date :必须符合日期格式YYYY-MM-DD
你还可以在点击提交按钮后才触发验证。
$("#formID").validationEngine({inlineValidation: false,
success : false,
failure : function() { callFailFunction() }
})
默认的是在鼠标失去焦点后才开始验证,也就是绑定的是blur事件,那如何改变呢?看下面的配置。
$("#formID").validationEngine({validationEventTriggers:"keyup blur", //will validate on keyup and blur
success : false,
failure : function() { callFailFunction() }
})
validationEventTriggers属性就是修改绑定事件,上面是增加了个keyup,也就是键盘按键起来就触发验证。
修改提示层的位置
$("#formID").validationEngine({promptPosition: "topRight", // OPENNING BOX POSITION, IMPLEMENTED: topLeft, topRight, bottomLeft, centerRight, bottomRight
success : false,
failure : function() {
})
promptPosition就是控制位置,有5种模式:topLeft, topRight, bottomLeft, centerRight, bottomRight
错误显示方式
$("#formID").validationEngine({
promptPosition: "topRight", // OPENNING BOX POSITION, IMPLEMENTED: topLeft, topRight, bottomLeft, centerRight, bottomRight
showTypes:2,//默认是1
success : false,
failure : function() {
})
ajax验证模式
$("#formID").validationEngine({ajaxSubmit: true,
ajaxSubmitFile: "ajaxSubmit.php",
ajaxSubmitMessage: "Thank you, we received your inscription!",
ajaxSubmitExtraData: "securityCode=38709238423&name=john",
success : false,
failure : function() {}
})
这几个参数很好理解。
ajaxSubmit: true, 提交表单使用ajax提交
ajaxSubmitFile: “ajaxSubmit.php”, 后台脚本
ajaxSubmitMessage 成功后显示的信息
ajaxSubmitExtraData 参数
这里需要对后台脚本返回的数据进行下说明:
返回的数据格式是json。
出现一个错误,产生一个数组,如下:
$arrayError[0][0] = "#email"; // FIELDID
$arrayError[0][1] = "Your email do not match.. whatever it need to match"; // TEXT ERROR
$arrayError[0][2] = "error"; // BOX COLOR
源代码
jquery.validationEngine-en.js
(function($){ $.fn.validationEngineLanguage = function(){ }; $.validationEngineLanguage = { newLang: function(){ $.validationEngineLanguage.allRules = { "required": { // Add your regex rules here, you can take telephone as an example "regex": "none", "alertText": "* 非空选项.", "alertTextCheckboxMultiple": "* 请选择一个单选框.", "alertTextCheckboxe": "* 请选择一个复选框." }, "length":{ "regex":"none", "alertText":"* 长度必须在 ", "alertText2":" 至 ", "alertText3": " 之间."}, "minSize": { "regex": "none", "alertText": "* 最小", "alertText2": " 允许的字符" }, "maxSize": { "regex": "none", "alertText": "* 最大 ", "alertText2": " 允许的字符" }, "min": { "regex": "none", "alertText": "* 最小的值是 " }, "max": { "regex": "none", "alertText": "* 最大的值是 " }, "past": { "regex": "none", "alertText": "* Date prior to " }, "future": { "regex": "none", "alertText": "* Date past " }, "maxCheckbox": { "regex": "none", "alertText": "* 最多选择 ", "alertText2": " 项." }, "minCheckbox": { "regex": "none", "alertText": "* 至少选择 ", "alertText2": " 项" }, "telephone":{ "regex":"/^(0[0-9]{2,3}\-)?([2-9][0-9]{6,7})+(\-[0-9]{1,4})?$/", "alertText":"* 请输入有效的电话号码,如:010-29292929." }, "mobilephone":{ "regex":"/^(13[0-9]|15[^4]|18[6|8|9])\d{8}$/", "alertText":"* 请输入有效的手机号码." }, "email":{ "regex":"/^[a-zA-Z0-9_\.\-]+\@([a-zA-Z0-9\-]+\.)+[a-zA-Z0-9]{2,4}$/", "alertText":"* 请输入有效的邮件地址." }, "chinese":{ "regex":"/^[\u4e00-\u9fa5]+$/", "alertText":"* 请输入中文." }, "equals": { "regex": "none", "alertText": "* 两次输入不一致,请重新输入." }, "phone": { // credit: jquery.h5validate.js / orefalo "regex": /^([\+][0-9]{1,3}[ \.\-])?([\(]{1}[0-9]{2,6}[\)])?([0-9 \.\-\/]{3,20})((x|ext|extension)[ ]?[0-9]{1,4})?$/, "alertText": "* Invalid phone number" }, "zipcode":{ "regex":"/^[1-9]\d{5}$/", "alertText":"* 请输入有效的邮政编码." }, "qq":{ "regex":"/^[1-9]\d{4,9}$/", "alertText":"* 请输入有效的QQ号码." }, // "email": { // // Shamelessly lifted from Scott Gonzalez via the Bassistance Validation plugin http://projects.scottsplayground.com/email_address_validation/ // "regex": /^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i, // "alertText": "* Invalid email address" // }, "integer": { "regex": /^[\-\+]?\d+$/, "alertText": "* 不是有效的整数" }, "number": { // Number, including positive, negative, and floating decimal. credit: orefalo "regex": /^[\-\+]?(([0-9]+)([\.,]([0-9]+))?|([\.,]([0-9]+))?)$/, "alertText": "* 无效的浮点十进制数" }, "date": { "regex": /^\d{4}[\/\-](0?[1-9]|1[012])[\/\-](0?[1-9]|[12][0-9]|3[01])$/, "alertText": "* 请输入有效的日期,如:2008-08-08." }, "ip": { "regex": /^((([01]?[0-9]{1,2})|(2[0-4][0-9])|(25[0-5]))[.]){3}(([0-1]?[0-9]{1,2})|(2[0-4][0-9])|(25[0-5]))$/, "alertText": "* 请输入有效的IP." }, "url": { "regex": /^(https?|ftp):\/\/(((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:)*@)?(((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5]))|((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?)(:\d*)?)(\/((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)+(\/(([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)*)*)?)?(\?((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|[\uE000-\uF8FF]|\/|\?)*)?(\#((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|\/|\?)*)?$/i, "alertText": "* 请输入有效的网址." }, "onlyNumber": { "regex": /^[0-9\ ]+$/, "alertText": "* 请输入数字." }, "onlyLetter": { "regex": /^[a-zA-Z\ \']+$/, "alertText": "* 请输入英文字母." }, "onlyLetterNumber": { "regex": /^[0-9a-zA-Z]+$/, "alertText": "* 请输入英文字母和数字." }, // --- CUSTOM RULES -- Those are specific to the demos, they can be removed or changed to your likings "ajaxUser": { "file": "ajaxback.aspx", // you may want to pass extra data on the ajax call "alertTextOk": "* 账号可以使用.", "alertText": "* 账号已被注册.", "alertTextLoad": "* 检查中,请稍候..." }, "CheckIDC": { "nname":"CheckIDC", "alertText":"* 身份证号码格式不对." }, "validate2fields": { "alertText": "* Please input HELLO" } }; } }; $.validationEngineLanguage.newLang(); })(jQuery);
jquery.validationEngine.js
CSS.CSS
View Code
using System; using System.Collections; using System.Configuration; using System.Data; using System.Linq; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.HtmlControls; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Xml.Linq; namespace validForm.phpajax { public partial class ajaxback : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { //string str = Request.QueryString["fieldValue"].ToString(); //string validateId = Request.QueryString["fieldId"].ToString(); //if (str != "zrj") //{ // Response.Write("true"); // Response.End(); //} //else //{ // Response.Write("false"); // Response.End(); //} } string str = Request.Form["validateValue"].ToString(); string validateId = Request.Form["validateId"].ToString(); string validateError = Request.Form["validateError"].ToString(); if (str != "zrj") { Response.Write("{'jsonValidateReturn':['" + validateId + "','" + validateError + "','true']}"); Response.End(); } else { Response.Write("{'jsonValidateReturn':['" + validateId + "','" + validateError + "','false']}"); Response.End(); } } } }
/* * Inline Form Validation Engine 1.7.3, jQuery plugin * * Copyright(c) 2010, Cedric Dugas * http://www.position-absolute.com * * Form validation engine allowing custom regex rules to be added. * Thanks to Francois Duquette and Teddy Limousin * and everyone helping me find bugs on the forum * Licenced under the MIT Licence * zrj 2011-7-5 */ (function($) { $.fn.validationEngine = function(settings) { if($.validationEngineLanguage){ // IS THERE A LANGUAGE LOCALISATION ? allRules = $.validationEngineLanguage.allRules; }else{ $.validationEngine.debug("Validation engine rules are not loaded check your external file"); } settings = jQuery.extend({ allrules:allRules, validationEventTriggers:"blur", inlineValidation: true, returnIsValid:false, liveEvent:false, openDebug: true, unbindEngine:true, containerOverflow:false, containerOverflowDOM:"", ajaxSubmit: false, scroll:true, promptPosition: "topRight", // OPENNING BOX POSITION, IMPLEMENTED: topLeft, topRight, bottomLeft, centerRight, bottomRight showTypes:1,//zrj 验证方式 success : false, beforeSuccess : function() {}, failure : function() {} }, settings); $.validationEngine.settings = settings; $.validationEngine.ajaxValidArray = []; // ARRAY FOR AJAX: VALIDATION MEMORY if(settings.inlineValidation === true){ // Validating Inline ? if(!settings.returnIsValid){ // NEEDED FOR THE SETTING returnIsValid // what the hell! orefalo //allowReturnIsvalid = false; if(settings.liveEvent){ // LIVE event, vast performance improvement over BIND $(this).find("[class*=validate]").live(settings.validationEventTriggers, function(caller){ if($(caller).attr("type") != "checkbox") _inlinEvent(this); }); $(this).find("[class*=validate][type=checkbox]").live("click", function(caller){ _inlinEvent(this); }); }else{ $(this).find("[class*=validate]").not("[type=checkbox]").bind(settings.validationEventTriggers, function(caller){ _inlinEvent(this); }); $(this).find("[class*=validate][type=checkbox]").bind("click", function(caller){ _inlinEvent(this); }); } // what the hell orefalo //firstvalid = false; } function _inlinEvent(caller){ $.validationEngine.settings = settings; if($.validationEngine.intercept === false || !$.validationEngine.intercept){ // STOP INLINE VALIDATION THIS TIME ONLY $.validationEngine.onSubmitValid=false; $.validationEngine.loadValidation(caller); }else{ $.validationEngine.intercept = false; } } } if (settings.returnIsValid){ // Do validation and return true or false, it bypass everything; if ($.validationEngine.submitValidation(this,settings)){ return false; }else{ return true; } } $(this).bind("submit", function(caller){ // ON FORM SUBMIT, CONTROL AJAX FUNCTION IF SPECIFIED ON DOCUMENT READY $.validationEngine.onSubmitValid = true; $.validationEngine.settings = settings; if($.validationEngine.submitValidation(this,settings) === false){ if($.validationEngine.submitForm(this,settings) === true) return false; }else{ // orefalo: what the hell is that ? settings.failure && settings.failure(); return false; } }); $(".formError").live("click",function(){ // REMOVE BOX ON CLICK $(this).fadeOut(150,function(){ $(this).remove(); }); }); }; $.validationEngine = { defaultSetting : function(caller) { // NOT GENERALLY USED, NEEDED FOR THE API, DO NOT TOUCH if($.validationEngineLanguage){ allRules = $.validationEngineLanguage.allRules; }else{ $.validationEngine.debug("Validation engine rules are not loaded check your external file"); } settings = { allrules:allRules, validationEventTriggers:"blur", inlineValidation: true, containerOverflow:false, containerOverflowDOM:"", returnIsValid:false, scroll:true, unbindEngine:true, ajaxSubmit: false, promptPosition: "topRight", // OPENNING BOX POSITION, IMPLEMENTED: topLeft, topRight, bottomLeft, centerRight, bottomRight showTypes:1,//zrj 验证方式 success : false, failure : function() {} }; $.validationEngine.settings = settings; }, loadValidation : function(caller) { // GET VALIDATIONS TO BE EXECUTED if(!$.validationEngine.settings) $.validationEngine.defaultSetting(); var rulesParsing = $(caller).attr('class'); var rulesRegExp = /\[(.*)\]/; var getRules = rulesRegExp.exec(rulesParsing); if(getRules === null) return false; var str = getRules[1]; var pattern = /\[|,|\]/; var result= str.split(pattern); var validateCalll = $.validationEngine.validateCall(caller,result); return validateCalll; }, validateCall : function(caller,rules) { // EXECUTE VALIDATION REQUIRED BY THE USER FOR THIS FIELD var promptText =""; if(!$(caller).attr("id")) $.validationEngine.debug("This field have no ID attribut( name & class displayed): "+$(caller).attr("name")+" "+$(caller).attr("class")); // what the hell! //caller = caller; ajaxValidate = false; var callerName = $(caller).attr("name"); $.validationEngine.isError = false; $.validationEngine.showTriangle = true; var callerType = $(caller).attr("type"); for (var i=0; i<rules.length;i++){ switch (rules[i]){ case "optional": if(!$(caller).val()){ $.validationEngine.closePrompt(caller); return $.validationEngine.isError; } break; case "required": _required(caller,rules); break; case "custom": _customRegex(caller,rules,i); break; case "exemptString": _exemptString(caller,rules,i); break; case "ajax": if(!$.validationEngine.onSubmitValid) _ajax(caller,rules,i); break; case "min": _min(caller,rules,i); break; case "max": _max(caller,rules,i); break; case "minSize": _minSize(caller,rules,i); break; case "maxSize": _maxSize(caller,rules,i); break; case "past": _past(caller,rules,i); break; case "future": _future(caller,rules,i); break; case "length": _length(caller,rules,i); break; case "maxCheckbox": _maxCheckbox(caller,rules,i); groupname = $(caller).attr("name"); caller = $("input[name='"+groupname+"']"); break; case "minCheckbox": _minCheckbox(caller,rules,i); groupname = $(caller).attr("name"); caller = $("input[name='"+groupname+"']"); break; case "equals": _equals(caller,rules,i); break; case "funcCall": _funcCall(caller,rules,i); break; default : } } radioHack(); if ($.validationEngine.isError === true){ //zrj 2011-7-4 if ($.validationEngine.settings.showTypes==2) { $.validationEngine.showMsg(caller,promptText); } else { var linkTofieldText = "." +$.validationEngine.linkTofield(caller); if(linkTofieldText != "."){ if(!$(linkTofieldText)[0]){ $.validationEngine.buildPrompt(caller,promptText,"error"); }else{ $.validationEngine.updatePromptText(caller,promptText); } }else{ $.validationEngine.updatePromptText(caller,promptText); } } }else{ if ($.validationEngine.settings.showTypes==2) { if ($.validationEngine.ajaxValid==true) { $(caller).removeClass("Validform_error");//移除文本框样式 $(caller).parent().next().find(".Validform_checktip").removeClass().addClass("Validform_checktip Validform_right").html("");//增加文本框验证通过信息 } } else { $.validationEngine.closePrompt(caller); } } /* UNFORTUNATE RADIO AND CHECKBOX GROUP HACKS */ /* As my validation is looping input with id's we need a hack for my validation to understand to group these inputs */ function radioHack(){ if($("input[name='"+callerName+"']").size()> 1 && (callerType == "radio" || callerType == "checkbox")) { // Hack for radio/checkbox group button, the validation go the first radio/checkbox of the group caller = $("input[name='"+callerName+"'][type!=hidden]:first"); $.validationEngine.showTriangle = false; } } /* VALIDATION FUNCTIONS */ function _required(caller,rules){ // VALIDATE BLANK FIELD var callerType = $(caller).attr("type"); if (callerType == "text" || callerType == "password" || callerType == "textarea"){ if(!$(caller).val()){ $.validationEngine.isError = true; promptText += $.validationEngine.settings.allrules[rules[i]].alertText+"<br />"; } } if (callerType == "radio" || callerType == "checkbox" ){ callerName = $(caller).attr("name"); if($("input[name='"+callerName+"']:checked").size() === 0) { $.validationEngine.isError = true; if($("input[name='"+callerName+"']").size() == 1) { promptText += $.validationEngine.settings.allrules[rules[i]].alertTextCheckboxe+"<br />"; }else{ promptText += $.validationEngine.settings.allrules[rules[i]].alertTextCheckboxMultiple+"<br />"; } } } if (callerType == "select-one") { // added by paul@kinetek.net for select boxes, Thank you if(!$(caller).val()) { $.validationEngine.isError = true; promptText += $.validationEngine.settings.allrules[rules[i]].alertText+"<br />"; } } if (callerType == "select-multiple") { // added by paul@kinetek.net for select boxes, Thank you if(!$(caller).find("option:selected").val()) { $.validationEngine.isError = true; promptText += $.validationEngine.settings.allrules[rules[i]].alertText+"<br />"; } } } function _customRegex(caller,rules,position){ // VALIDATE REGEX RULES var customRule = rules[position+1]; var pattern = eval($.validationEngine.settings.allrules[customRule].regex); if(!pattern.test($(caller).attr('value'))){ $.validationEngine.isError = true; promptText += $.validationEngine.settings.allrules[customRule].alertText+"<br />"; } } function _exemptString(caller,rules,position){ // VALIDATE REGEX RULES var customString = rules[position+1]; if(customString == $(caller).attr('value')){ $.validationEngine.isError = true; promptText += $.validationEngine.settings.allrules['required'].alertText+"<br />"; } } function _funcCall(caller,rules,position){ var customRule = rules[position+1]; var funce = $.validationEngine.settings.allrules[customRule].nname; var fn = window[funce]; if (typeof(fn) === 'function'){ var fn_result = fn(); if(!fn_result){ $.validationEngine.isError = true; } promptText += $.validationEngine.settings.allrules[customRule].alertText+"<br />"; } } function _ajax(caller,rules,position){ // VALIDATE AJAX RULES customAjaxRule = rules[position+1]; postfile = $.validationEngine.settings.allrules[customAjaxRule].file; fieldValue = $(caller).val(); ajaxCaller = caller; fieldId = $(caller).attr("id"); ajaxValidate = true; ajaxisError = $.validationEngine.isError; if($.validationEngine.settings.allrules[customAjaxRule].extraData){ extraData = $.validationEngine.settings.allrules[customAjaxRule].extraData; }else{ extraData = ""; } /* AJAX VALIDATION HAS ITS OWN UPDATE AND BUILD UNLIKE OTHER RULES */ if(!ajaxisError){ $.ajax({ type: "POST", url: postfile, async: true, data: "validateValue="+fieldValue+"&validateId="+fieldId+"&validateError="+customAjaxRule, beforeSend: function(){ // BUILD A LOADING PROMPT IF LOAD TEXT EXIST if($.validationEngine.settings.allrules[customAjaxRule].alertTextLoad){ if ($.validationEngine.settings.showTypes==2) { $(caller).parent().next().find(".Validform_checktip").removeClass().addClass("Validform_checktip Validform_loading").text($.validationEngine.settings.allrules[customAjaxRule].alertTextLoad); } else { if(!$("div."+fieldId+"formError")[0]){ return $.validationEngine.buildPrompt(ajaxCaller,$.validationEngine.settings.allrules[customAjaxRule].alertTextLoad,"load"); }else{ $.validationEngine.updatePromptText(ajaxCaller,$.validationEngine.settings.allrules[customAjaxRule].alertTextLoad,"load"); } } } }, error: function(data,transport){ $.validationEngine.debug("error in the ajax: "+data.status+" "+transport); }, success: function(data){ // GET SUCCESS DATA RETURN JSON data = eval( "("+data+")"); // GET JSON DATA FROM PHP AND PARSE IT ajaxisError = data.jsonValidateReturn[2]; customAjaxRule = data.jsonValidateReturn[1]; ajaxCaller = $("#"+data.jsonValidateReturn[0])[0]; fieldId = ajaxCaller; ajaxErrorLength = $.validationEngine.ajaxValidArray.length; existInarray = false; if(ajaxisError == "false"){ // DATA FALSE UPDATE PROMPT WITH ERROR; _checkInArray(false); // Check if ajax validation alreay used on this field if(!existInarray){ // Add ajax error to stop submit $.validationEngine.ajaxValidArray[ajaxErrorLength] = new Array(2); $.validationEngine.ajaxValidArray[ajaxErrorLength][0] = fieldId; $.validationEngine.ajaxValidArray[ajaxErrorLength][1] = false; existInarray = false; } $.validationEngine.ajaxValid = false; promptText += $.validationEngine.settings.allrules[customAjaxRule].alertText+"<br />"; if ($.validationEngine.settings.showTypes==2) { $.validationEngine.showMsg(caller,promptText); } else { $.validationEngine.updatePromptText(ajaxCaller,promptText,"",true); } }else{ _checkInArray(true); $.validationEngine.ajaxValid = true; if(!customAjaxRule) { $.validationEngine.debug("wrong ajax response, are you on a server or in xampp? if not delete de ajax[ajaxUser] validating rule from your form ");} if($.validationEngine.settings.allrules[customAjaxRule].alertTextOk){ // NO OK TEXT MEAN CLOSE PROMPT if ($.validationEngine.settings.showTypes==2) { $(caller).removeClass("Validform_error");//移除文本框样式 $(caller).parent().next().find(".Validform_checktip").removeClass().addClass("Validform_checktip Validform_right").html("");//增加文本框验证通过信息 } else { $.validationEngine.updatePromptText(ajaxCaller,$.validationEngine.settings.allrules[customAjaxRule].alertTextOk,"pass",true); } }else{ ajaxValidate = false; $.validationEngine.closePrompt(ajaxCaller); } } function _checkInArray(validate){ for(var x=0 ;x<ajaxErrorLength;x++){ if($.validationEngine.ajaxValidArray[x][0] == fieldId){ $.validationEngine.ajaxValidArray[x][1] = validate; existInarray = true; } } } } }); } } function _equals(caller,rules,position){ // VALIDATE FIELD MATCH var equalsField = rules[position+1]; if($(caller).attr('value') != $("#"+equalsField).attr('value')){ $.validationEngine.isError = true; promptText += $.validationEngine.settings.allrules["equals"].alertText+"<br />"; } } function _length(caller,rules,position){ // VALIDATE LENGTH var startLength = eval(rules[position+1]); var endLength = eval(rules[position+2]); var feildLength = $(caller).attr('value').length; if(feildLength<startLength || feildLength>endLength){ $.validationEngine.isError = true; promptText += $.validationEngine.settings.allrules["length"].alertText+startLength+$.validationEngine.settings.allrules["length"].alertText2+endLength+$.validationEngine.settings.allrules["length"].alertText3+"<br />"; } } function _minSize(caller,rules,position){ var min = rules[position+1]; var len = $(caller).val().length; if (len < min){ $.validationEngine.isError = true; promptText +=$.validationEngine.settings.allrules["minSize"].alertText + min + $.validationEngine.settings.allrules["minSize"].alertText2+"<br />"; } } function _maxSize(caller,rules,position){ var max=rules[position+1]; var len=$(caller).val().length; if (len > max) { $.validationEngine.isError = true; var rule=$.validationEngine.settings.allrules["maxSize"]; promptText +=rule.alertText + max + rule.alertText2 + "<br />"; } } function _min(caller,rules,position){ var min=parseFloat(rules[position+1]); var len=parseFloat($(caller).val()); if (len < min ) { $.validationEngine.isError = true; var rule=$.validationEngine.settings.allrules["min"]; if (rule.alertText2) promptText +=rule.alertText + min + rule.alertText2+"<br />"; promptText +=rule.alertText+min +"<br />" } } function _max(caller,rules,position){ var max=parseFloat(rules[position +1]); var len=parseFloat($(caller).val()); if (len >max) { $.validationEngine.isError = true; var rule=$.validationEngine.settings.allrules["max"]; if (rule.alertText2) promptText +=rule.alertText + min + rule.alertText2+"<br />"; promptText +=rule.alertText+max +"<br />" } } function _past(caller,rules,position){ var p=rules[position+1]; var pdate=(p.toLowerCase()=="now")?new Date():_parseDate(p); var vdate=_parseDate($(caller).val()); if (vdate <pdate) { $.validationEngine.isError = true; var rule=$.validationEngine.settings.allrules["past"]; if (rule.alertText2) promptText += rule.alertText + _dateToString(pdate) + rule.alertText2+"<br />"; promptText += rule.alertText + _dateToString(pdate)+"<br />"; } } function _future(caller, rules, position) { var p=rules[position + 1]; var pdate = (p.toLowerCase() == "now")? new Date(): _parseDate(p); var vdate = _parseDate($(caller).val()); if (vdate > pdate ) { var rule = options.allrules.future; if (rule.alertText2) promptText += rule.alertText + _dateToString(pdate) + rule.alertText2+"<br />"; promptText += rule.alertText + _dateToString(pdate)+"<br />"; } } function _dateToString(date) { return date.getFullYear()+"-"+(date.getMonth()+1)+"-"+date.getDate(); } /** * Parses an ISO date * @param {String} d */ function _parseDate(d) { var dateParts = d.split("-"); if(dateParts==d) dateParts = d.split("/"); return new Date(dateParts[0], (dateParts[1] - 1) ,dateParts[2]); } function _maxCheckbox(caller,rules,position){ // VALIDATE CHECKBOX NUMBER var nbCheck = eval(rules[position+1]); var groupname = $(caller).attr("name"); var groupSize = $("input[name='"+groupname+"']:checked").size(); if(groupSize > nbCheck){ $.validationEngine.showTriangle = false; $.validationEngine.isError = true; promptText += $.validationEngine.settings.allrules["maxCheckbox"].alertText+"<br />"; } } function _minCheckbox(caller,rules,position){ // VALIDATE CHECKBOX NUMBER var nbCheck = eval(rules[position+1]); var groupname = $(caller).attr("name"); var groupSize = $("input[name='"+groupname+"']:checked").size(); if(groupSize < nbCheck){ $.validationEngine.isError = true; $.validationEngine.showTriangle = false; promptText += $.validationEngine.settings.allrules["minCheckbox"].alertText+" "+nbCheck+" "+$.validationEngine.settings.allrules["minCheckbox"].alertText2+"<br />"; } } return ($.validationEngine.isError) ? $.validationEngine.isError : false; }, submitForm : function(caller){ if ($.validationEngine.settings.success) { // AJAX SUCCESS, STOP THE LOCATION UPDATE if($.validationEngine.settings.unbindEngine) $(caller).unbind("submit"); var serializedForm = $(caller).serialize(); $.validationEngine.settings.success && $.validationEngine.settings.success(serializedForm); return true; } return false; }, showMsg: function (caller,promptText) { if(!$.validationEngine.settings) { $.validationEngine.defaultSetting(); } if (promptText !="") { var str=promptText.split("<br />"); if (str.length>1) { promptText=str[str.length-2]; } else { promptText=str[0]; } } $(caller).addClass("Validform_error"); $(caller).parent().next().find(".Validform_checktip").removeClass().addClass("Validform_wrong Validform_checktip").text(promptText); }, buildPrompt : function(caller,promptText,type,ajaxed) { // ERROR PROMPT CREATION AND DISPLAY WHEN AN ERROR OCCUR if(!$.validationEngine.settings) { $.validationEngine.defaultSetting(); } var deleteItself = "." + $(caller).attr("id") + "formError"; //$("#"+tx).attr("style",";border-color:Red;"); if($(deleteItself)[0]) { $(deleteItself).stop(); $(deleteItself).remove(); } var divFormError = document.createElement('div'); var formErrorContent = document.createElement('div'); var linkTofield = $.validationEngine.linkTofield(caller); $(divFormError).addClass("formError"); if(type == "pass") $(divFormError).addClass("greenPopup"); if(type == "load") $(divFormError).addClass("blackPopup"); if(ajaxed) $(divFormError).addClass("ajaxed"); $(divFormError).addClass(linkTofield); $(formErrorContent).addClass("formErrorContent"); if($.validationEngine.settings.containerOverflow) // Is the form contained in an overflown container? $(caller).before(divFormError); else $("body").append(divFormError); $(divFormError).append(formErrorContent); if($.validationEngine.showTriangle != false){ // NO TRIANGLE ON MAX CHECKBOX AND RADIO var arrow = document.createElement('div'); $(arrow).addClass("formErrorArrow"); $(divFormError).append(arrow); if($.validationEngine.settings.promptPosition == "bottomLeft" || $.validationEngine.settings.promptPosition == "bottomRight") { $(arrow).addClass("formErrorArrowBottom"); $(arrow).html('<div class="line1"><!-- --></div><div class="line2"><!-- --></div><div class="line3"><!-- --></div><div class="line4"><!-- --></div><div class="line5"><!-- --></div><div class="line6"><!-- --></div><div class="line7"><!-- --></div><div class="line8"><!-- --></div><div class="line9"><!-- --></div><div class="line10"><!-- --></div>'); } else if($.validationEngine.settings.promptPosition == "topLeft" || $.validationEngine.settings.promptPosition == "topRight"){ $(divFormError).append(arrow); $(arrow).html('<div class="line10"><!-- --></div><div class="line9"><!-- --></div><div class="line8"><!-- --></div><div class="line7"><!-- --></div><div class="line6"><!-- --></div><div class="line5"><!-- --></div><div class="line4"><!-- --></div><div class="line3"><!-- --></div><div class="line2"><!-- --></div><div class="line1"><!-- --></div>'); } } $(formErrorContent).html(promptText); var calculatedPosition = $.validationEngine.calculatePosition(caller,promptText,type,ajaxed,divFormError); calculatedPosition.callerTopPosition +="px"; calculatedPosition.callerleftPosition +="px"; calculatedPosition.marginTopSize +="px"; if ( $.browser.msie && /6.0/.test(navigator.userAgent) ) { $(divFormError).append('<iframe class="iframe" frameborder="0" scr="javascript:false;"></iframe>'); } $(divFormError).css({ "top":calculatedPosition.callerTopPosition, "left":calculatedPosition.callerleftPosition, "marginTop":calculatedPosition.marginTopSize, "opacity":0 }); //orefalo - what the hell //return $(divFormError).animate({"opacity":0.87},function(){return true;}); return $(divFormError).animate({"opacity":0.87}); }, updatePromptText : function(caller,promptText,type,ajaxed) { // UPDATE TEXT ERROR IF AN ERROR IS ALREADY DISPLAYED var linkTofield = $.validationEngine.linkTofield(caller); var updateThisPrompt = "."+linkTofield; if(type == "pass") $(updateThisPrompt).addClass("greenPopup"); else $(updateThisPrompt).removeClass("greenPopup"); if(type == "load") $(updateThisPrompt).addClass("blackPopup"); else $(updateThisPrompt).removeClass("blackPopup"); if(ajaxed) $(updateThisPrompt).addClass("ajaxed"); else $(updateThisPrompt).removeClass("ajaxed"); $(updateThisPrompt).find(".formErrorContent").html(promptText); var calculatedPosition = $.validationEngine.calculatePosition(caller,promptText,type,ajaxed,updateThisPrompt); calculatedPosition.callerTopPosition +="px"; calculatedPosition.callerleftPosition +="px"; calculatedPosition.marginTopSize +="px"; $(updateThisPrompt).animate({ "top":calculatedPosition.callerTopPosition,"marginTop":calculatedPosition.marginTopSize }); }, calculatePosition : function(caller,promptText,type,ajaxed,divFormError){ var callerTopPosition,callerleftPosition,inputHeight,marginTopSize; var callerWidth = $(caller).width(); if($.validationEngine.settings.containerOverflow){ // Is the form contained in an overflown container? callerTopPosition = 0; callerleftPosition = 0; inputHeight = $(divFormError).height(); // compasation for the triangle marginTopSize = "-"+inputHeight; }else{ callerTopPosition = $(caller).offset().top; callerleftPosition = $(caller).offset().left; inputHeight = $(divFormError).height(); marginTopSize = 0; } /* POSITIONNING */ if($.validationEngine.settings.promptPosition == "topRight"){ if($.validationEngine.settings.containerOverflow){ // Is the form contained in an overflown container? callerleftPosition += callerWidth -30; }else{ callerleftPosition += callerWidth -30; callerTopPosition += -inputHeight; } } if($.validationEngine.settings.promptPosition == "topLeft"){ callerTopPosition += -inputHeight -10; } if($.validationEngine.settings.promptPosition == "centerRight"){ callerleftPosition += callerWidth +13; } if($.validationEngine.settings.promptPosition == "bottomLeft"){ callerTopPosition = callerTopPosition + $(caller).height() + 15; } if($.validationEngine.settings.promptPosition == "bottomRight"){ callerleftPosition += callerWidth -30; callerTopPosition += $(caller).height() +5; } return { "callerTopPosition":callerTopPosition, "callerleftPosition":callerleftPosition, "marginTopSize":marginTopSize }; }, linkTofield : function(caller){ var linkTofield = $(caller).attr("id") + "formError"; linkTofield = linkTofield.replace(/\[/g,""); linkTofield = linkTofield.replace(/\]/g,""); return linkTofield; }, closePrompt : function(caller,outside) { // CLOSE PROMPT WHEN ERROR CORRECTED if(!$.validationEngine.settings){ $.validationEngine.defaultSetting(); } if(outside){ $(caller).fadeTo("fast",0,function(){ $(caller).remove(); }); return false; } // orefalo -- review conditions non sense if(typeof(ajaxValidate)=='undefined') { ajaxValidate = false; } if(!ajaxValidate){ var linkTofield = $.validationEngine.linkTofield(caller); var closingPrompt = "."+linkTofield; $(closingPrompt).fadeTo("fast",0,function(){ $(closingPrompt).remove(); }); } }, debug : function(error) { if(!$.validationEngine.settings.openDebug) return false; if(!$("#debugMode")[0]){ $("body").append("<div id='debugMode'><div class='debugError'><strong>This is a debug mode, you got a problem with your form, it will try to help you, refresh when you think you nailed down the problem</strong></div></div>"); } $(".debugError").append("<div class='debugerror'>"+error+"</div>"); }, submitValidation : function(caller) { // FORM SUBMIT VALIDATION LOOPING INLINE VALIDATION if(!$.validationEngine.settings) { $.validationEngine.defaultSetting(); } var stopForm = false; //$.validationEngine.ajaxValid = true; var toValidateSize = $(caller).find("[class*=validate]").size(); $(caller).find("[class*=validate]").each(function(){ var linkTofield = $.validationEngine.linkTofield(this); if(!$("."+linkTofield).hasClass("ajaxed")){ // DO NOT UPDATE ALREADY AJAXED FIELDS (only happen if no normal errors, don't worry) var validationPass = $.validationEngine.loadValidation(this); return(validationPass) ? stopForm = true : ""; }; }); var ajaxErrorLength = $.validationEngine.ajaxValidArray.length; // LOOK IF SOME AJAX IS NOT VALIDATE for(var x=0;x<ajaxErrorLength;x++){ if($.validationEngine.ajaxValidArray[x][1] == false) $.validationEngine.ajaxValid = false; } if ($.validationEngine.settings.showTypes==2) { if (stopForm || !$.validationEngine.ajaxValid) { return true; } else { return false; } } else { if(stopForm || !$.validationEngine.ajaxValid){ // GET IF THERE IS AN ERROR OR NOT FROM THIS VALIDATION FUNCTIONS if($.validationEngine.settings.scroll){ if(!$.validationEngine.settings.containerOverflow){ var destination = $(".formError:not('.greenPopup'):first").offset().top; $(".formError:not('.greenPopup')").each(function(){ var testDestination = $(this).offset().top; if(destination>testDestination) destination = $(this).offset().top; }); $("html:not(:animated),body:not(:animated)").animate({ scrollTop: destination}, 1100); }else{ var destination = $(".formError:not('.greenPopup'):first").offset().top; var scrollContainerScroll = $($.validationEngine.settings.containerOverflowDOM).scrollTop(); var scrollContainerPos = - parseInt($($.validationEngine.settings.containerOverflowDOM).offset().top); destination = scrollContainerScroll + destination + scrollContainerPos -5; var scrollContainer = $.validationEngine.settings.containerOverflowDOM+":not(:animated)"; $(scrollContainer).animate({ scrollTop: destination}, 1100); } } return true; }else{ return false; } } } }; })(jQuery);
相关文章推荐
- validationEngine中文版 — jquery强大的表单验证插件
- validationEngine中文版-jquery强大的表单验证插件
- validationEngine中文版 — jquery强大的表单验证插件
- validationEngine中文版 — jquery强大的表单验证插件
- 【jQuery】validationEngine中文版 — jquery强大的表单验证插件
- validationEngine中文版 — jquery强大的表单验证插件
- validationEngine中文版 — jquery强大的表单验证插件
- validationEngine中文版 — jquery强大的表单验证插件
- validationEngine中文版 — jquery强大的表单验证插件
- (转)强大的JQuery表单验证插件 FormValidator使用介绍
- 功能非常强大的表单验证插件jQuery formValidator
- jquery强大的表单验证插件
- jquery validate强大的jquery表单验证插件
- jquery validate强大的jquery表单验证插件
- jquery validate强大的jquery表单验证插件
- 功能强大的jquery.validate表单验证插件
- jQuery Validate插件实现表单强大的验证功能
- jQuery Validate插件实现表单强大的验证功能
- 基于Bootstrup的强大jQuery表单验证插件
- jQuery - Validate插件为表单提供强大的验证功能