您的位置:首页 > Web前端 > JQuery

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

一:简单说明下使用教程:

引入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);
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: