Maison >interface Web >js tutoriel >jquery.validate Méthodes de validation personnalisées et validation des paramètres associés_jquery
Jquery Valider les paramètres associés
//定义中文消息 var cnmsg = { required: “必选字段”, remote: “请修正该字段”, email: “请输入正确格式的电子邮件”, url: “请输入合法的网址”, date: “请输入合法的日期”, dateISO: “请输入合法的日期 (ISO).”, number: “请输入合法的数字”, digits: “只能输入整数”, creditcard: “请输入合法的信用卡号”, equalTo: “请再次输入相同的值”, accept: “请输入拥有合法后缀名的字符串”, maxlength: jQuery.format(“请输入一个长度最多是 {0} 的字符串”), minlength: jQuery.format(“请输入一个长度最少是 {0} 的字符串”), rangelength: jQuery.format(“请输入一个长度介于 {0} 和 {1} 之间的字符串”), range: jQuery.format(“请输入一个介于 {0} 和 {1} 之间的值”), max: jQuery.format(“请输入一个最大为 {0} 的值”), min: jQuery.format(“请输入一个最小为 {0} 的值”) }; jQuery.extend(jQuery.validator.messages, cnmsg);
valider la vérification personnalisée
$(document).ready( function() { /** * 身份证号码验证 * */ function isIdCardNo(num) { var factorArr = new Array(7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2,1); var parityBit=new Array("1","0","X","9","8","7","6","5","4","3","2"); var varArray = new Array(); var intValue; var lngProduct = 0; var intCheckDigit; var intStrLen = num.length; var idNumber = num; // initialize if ((intStrLen != 15) && (intStrLen != 18)) { return false; } // check and set value for(i=0;i<intStrLen;i++) { varArray[i] = idNumber.charAt(i); if ((varArray[i] < '0' || varArray[i] > '9') && (i != 17)) { return false; } else if (i < 17) { varArray[i] = varArray[i] * factorArr[i]; } } if (intStrLen == 18) { //check date var date8 = idNumber.substring(6,14); if (isDate8(date8) == false) { return false; } // calculate the sum of the products for(i=0;i<17;i++) { lngProduct = lngProduct + varArray[i]; } // calculate the check digit intCheckDigit = parityBit[lngProduct % 11]; // check last digit if (varArray[17] != intCheckDigit) { return false; } } else{ //length is 15 //check date var date6 = idNumber.substring(6,12); if (isDate6(date6) == false) { return false; } } return true; } /** * 判断是否为“YYYYMM”式的时期 * */ function isDate6(sDate) { if(!/^[0-9]{6}$/.test(sDate)) { return false; } var year, month, day; year = sDate.substring(0, 4); month = sDate.substring(4, 6); if (year < 1700 || year > 2500) return false if (month < 1 || month > 12) return false return true } /** * 判断是否为“YYYYMMDD”式的时期 * */ function isDate8(sDate) { if(!/^[0-9]{8}$/.test(sDate)) { return false; } var year, month, day; year = sDate.substring(0, 4); month = sDate.substring(4, 6); day = sDate.substring(6, 8); var iaMonthDays = [31,28,31,30,31,30,31,31,30,31,30,31] if (year < 1700 || year > 2500) return false if (((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0)) iaMonthDays[1]=29; if (month < 1 || month > 12) return false if (day < 1 || day > iaMonthDays[month - 1]) return false return true } // 身份证号码验证 jQuery.validator.addMethod("idcardno", function(value, element) { return this.optional(element) || isIdCardNo(value); }, "请正确输入身份证号码"); //字母数字 jQuery.validator.addMethod("alnum", function(value, element) { return this.optional(element) || /^[a-zA-Z0-9]+$/.test(value); }, "只能包括英文字母和数字"); // 邮政编码验证 jQuery.validator.addMethod("zipcode", function(value, element) { var tel = /^[0-9]{6}$/; return this.optional(element) || (tel.test(value)); }, "请正确填写邮政编码"); // 汉字 jQuery.validator.addMethod("chcharacter", function(value, element) { var tel = /^[\u4e00-\u9fa5]+$/; return this.optional(element) || (tel.test(value)); }, "请输入汉字"); // 字符最小长度验证(一个中文字符长度为2) jQuery.validator.addMethod("stringMinLength", function(value, element, param) { var length = value.length; for ( var i = 0; i < value.length; i++) { if (value.charCodeAt(i) > 127) { length++; } } return this.optional(element) || (length >= param); }, $.validator.format("长度不能小于{0}!")); // 字符最大长度验证(一个中文字符长度为2) jQuery.validator.addMethod("stringMaxLength", function(value, element, param) { var length = value.length; for ( var i = 0; i < value.length; i++) { if (value.charCodeAt(i) > 127) { length++; } } return this.optional(element) || (length <= param); }, $.validator.format("长度不能大于{0}!")); // 字符验证 jQuery.validator.addMethod("string", function(value, element) { return this.optional(element) || /^[\u0391-\uFFE5\w]+$/.test(value); }, "不允许包含特殊符号!"); // 手机号码验证 jQuery.validator.addMethod("mobile", function(value, element) { var length = value.length; return this.optional(element) || (length == 11 && /^(((13[0-9]{1})|(15[0-9]{1}))+\d{8})$/.test(value)); }, "手机号码格式错误!"); // 电话号码验证 jQuery.validator.addMethod("phone", function(value, element) { var tel = /^(\d{3,4}-?)?\d{7,9}$/g; return this.optional(element) || (tel.test(value)); }, "电话号码格式错误!"); // 邮政编码验证 jQuery.validator.addMethod("zipCode", function(value, element) { var tel = /^[0-9]{6}$/; return this.optional(element) || (tel.test(value)); }, "邮政编码格式错误!"); // 必须以特定字符串开头验证 jQuery.validator.addMethod("begin", function(value, element, param) { var begin = new RegExp("^" + param); return this.optional(element) || (begin.test(value)); }, $.validator.format("必须以 {0} 开头!")); // 验证两次输入值是否不相同 jQuery.validator.addMethod("notEqualTo", function(value, element, param) { return value != $(param).val(); }, $.validator.format("两次输入不能相同!")); // 验证值不允许与特定值等于 jQuery.validator.addMethod("notEqual", function(value, element, param) { return value != param; }, $.validator.format("输入值不允许为{0}!")); // 验证值必须大于特定值(不能等于) jQuery.validator.addMethod("gt", function(value, element, param) { return value > param; }, $.validator.format("输入值必须大于{0}!")); // 验证值小数位数不能超过两位 jQuery.validator.addMethod("decimal", function(value, element) { var decimal = /^-?\d+(\.\d{1,2})?$/; return this.optional(element) || (decimal.test(value));
Utilisation de jQuery.validate
Lundi 12 avril 2010 14:33
Nom Type de retour Description
validate(options) renvoie : validateur pour vérifier le FORMULAIRE sélectionné
valid() renvoie : Booléen pour vérifier si la vérification est réussie
rules() renvoie : Options Renvoie les règles de validation de l'élément
rules(add,rules) renvoie : options pour ajouter des règles de vérification
règles (supprimer,règles)
jquery.validate est un très excellent framework de vérification basé sur jquery. Grâce à lui, nous pouvons vérifier rapidement certaines entrées courantes et étendre nos propres méthodes de vérification. Il prend également en charge l'internationalisation.
Site officiel de jquery.validate : http://bassistance.de/jquery-plugins/jquery-plugin-validation/
Utilisation :
1. Téléchargez d'abord jquery.js et jquery.validate.js et importez le fichier js (remarque : jquery doit être introduit avant jquery.validate.js, sinon une erreur sera signalée)
<script type="text/javascript" src="jquery.js"></script> <script type="text/javascript" src="jquery.validate.js"></script>
2. Écrivez le code du formulaire qui doit être vérifié et écrivez le code de vérification (il existe deux façons d'écrire le code de vérification, utilisez d'abord la méthode normale)
var validator = $("formId").validate({// #formId为需要进行验证的表单ID errorElement :"div",// 使用"div"标签标记错误, 默认:"label" wrapper:"li",// 使用"li"标签再把上边的errorELement包起来 errorClass :"validate-error",// 错误提示的css类名"error" onsubmit:true,// 是否在提交是验证,默认:true onfocusout:true,// 是否在获取焦点时验证,默认:true onkeyup :true,// 是否在敲击键盘时验证,默认:true onclick:false,// 是否在鼠标点击时验证(一般验证checkbox,radiobox) focusCleanup:false,// 当未通过验证的元素获得焦点时,并移除错误提示 rules: { loginName: {// 需要进行验证的输入框name required: true// 验证条件:必填 }, loginPassword: {// 需要进行验证的输入框name required: true,// 验证条件:必填 minlength: 5// 验证条件:最小长度为5 }, email: {// 需要进行验证的输入框name required: true,// 验证条件:必填 email: true// 验证条件:格式为email } }, messages: { loginName: { required: "用户名不允许为空!"// 验证未通过的消息 }, loginPassword: { required: "密码不允许为空!", minlength: jQuery.format("密码至少输入 {0} 字符!") }, email: { required: "email不允许为空", email: "邮件地址格式错误!" } }
2. Utilisez la méthode méta String pour la vérification, c'est-à-dire vérifiez le contenu et écrivez-le dans la classe (notez que la méthode méta String nécessite l'introduction du fichier jquery.metadata.js)
<script type="text/javascript" src="jquery.js"></script> <script type="text/javascript" src="jquery.metadata.js"></script> <script type="text/javascript" src="jquery.validate.js"></script> <form id="validate" action="admin/transfer!save.action" method="post"> <input type="text" class="required" name="entity.name" /> <input type="text" class="email" name="entity.email" /> <input type="submit" class="button" value="提 交" /> </form> <script type="text/javascript"> $(document).ready( function() { $("#formId").validate({// #formId为需要进行验证的表单ID meta :"validate"// 采用meta String方式进行验证(验证内容与写入class中) errorElement :"div",// 使用"div"标签标记错误, 默认:"label" wrapper:"li",// 使用"li"标签再把上边的errorELement包起来 errorClass :"validate-error",// 错误提示的css类名"error" onsubmit:true,// 是否在提交是验证,默认:true onfocusout:true,// 是否在获取焦点时验证,默认:true onkeyup :true,// 是否在敲击键盘时验证,默认:true onclick:false,// 是否在鼠标点击时验证(一般验证checkbox,radiobox) focusCleanup:false,// 当未通过验证的元素获得焦点时,并移除错误提示 }); }) </script>
Remarque : dans les applications Struts2, nous rencontrons souvent des formulaires de saisie sous la forme name="entity.name" (c'est-à-dire que lorsque le nom contient des virgules ou d'autres symboles spéciaux), nous pouvons mettre le nom ci-dessus entre guillemets ( "") C'est tout, comme :
rules: { "entity.loginName": {// 需要进行验证的输入框name required: true// 验证条件:必填 } }, messages: { "entity.loginName": { required: "用户名不允许为空!"// 验证未通过的消息 } }
Vous pouvez m'envoyer un e-mail : happyczx@126.com Bienvenue pour discuter ensemble des problèmes liés à la technologie Java
.Une partie du code ci-dessus provient du système de paiement open source payj. Ce projet java open source contient de nombreux excellents codes sources d'application de Struts2 spring hibernate jquery et d'autres frameworks, qui valent le détour. Je voudrais d’abord le recommander ici, haha. . .
ps : Jquery Valider les règles de vérification
(1)obligatoire : vrai champ obligatoire
(2)remote : "check.php" Utilisez la méthode ajax pour appeler check.php pour vérifier la valeur d'entrée
(3)email:true Vous devez saisir un email au bon format
(4)url:true Vous devez saisir l'URL dans le bon format
(5)date:true Vous devez saisir la date dans le bon format
(6)dateISO:true Vous devez saisir la date (ISO) dans le bon format, par exemple : 2009-06-23, 1998/01/22 Seul le format est vérifié, pas la validité
(7)numéro : vrai Vous devez saisir un numéro légal (nombre négatif, décimal)
(8)chiffres : vrai doit saisir un entier
(9)carte de crédit : Un numéro de carte de crédit légal doit être saisi
(10)equalTo : "#field" La valeur d'entrée doit être la même que #field
(11)accepter : saisissez une chaîne avec un suffixe légal (le suffixe du fichier téléchargé)
(12)maxlength:5 Saisissez une chaîne d'une longueur maximale de 5 (les caractères chinois comptent pour un caractère)
(13)minlength:10 Saisissez une chaîne d'une longueur minimale de 10 (les caractères chinois comptent pour un caractère)
(14)rangelength :[5,10] La longueur de saisie doit être comprise entre 5 et 10") (les caractères chinois comptent pour un caractère)
(15)range :[5,10] La valeur d'entrée doit être comprise entre 5 et 10
(16)max:5 La valeur d'entrée ne peut pas être supérieure à 5
(17)min:10 La valeur d'entrée ne peut pas être inférieure à 10
Jquery Valider soumettre soumettre
submitHandler : la fonction exécutée après avoir réussi la vérification doit inclure la fonction de soumission du formulaire, sinon le formulaire ne sera pas soumis
$(".selector").validate({ submitHandler:function(form) { $(form).ajaxSubmit(); //Utiliser la fonction Jquery Form } })
Jquery Validate erreur invite d'erreur dom
.errorPlacement : Callback Default : Mettre le message d'erreur après l'élément validé
Spécifiez l'emplacement où l'erreur est placée. La valeur par défaut est : error.appendTo(element.parent()); c'est-à-dire que le message d'erreur est placé derrière l'élément vérifié
.
errorPlacement: function(error, element) { error.appendTo(element.parent()); }
Définissez le style de l'invite d'erreur, vous pouvez ajouter l'affichage d'icônes, comme :
input.error { border: 1px solid red; } label.error { background:url(“./demo/images/unchecked.gif”) no-repeat 0px 0px; padding-left: 16px; padding-bottom: 2px; font-weight: bold; color: #EA5200; }