- 浏览: 165110 次
- 性别:
- 来自: 武汉
文章分类
- 全部博客 (95)
- oracle (7)
- java 基础 (10)
- web层 (3)
- 框架技术 (0)
- eclipse技巧 (2)
- 重构 (2)
- 架构 (1)
- 缓存 (11)
- 分布式多线程编程 (5)
- jquery (8)
- ibatis (3)
- spring API (1)
- maven (1)
- spring (4)
- js (12)
- 正则表达式 (1)
- Velocit (1)
- 杂七杂八 (3)
- XSS跨域攻击 (1)
- appfuse (2)
- Simple-Spring-Memcached (3)
- spring batch (11)
- spring integration (2)
- Teiid 8.0 (0)
- Linux 命令 (1)
最新评论
-
luxianping:
怎么根据命名空间来删除缓存? 比如说用户对应的菜单,当有用户 ...
使用SSM注解做缓存操作 -
vemacitri_b:
mowengaobo 写道你可以这样理解key。为什么不单独放 ...
使用SSM注解做缓存操作 -
mowengaobo:
你可以这样理解key。为什么不单独放个参数出来如 @Rea ...
使用SSM注解做缓存操作 -
夜神月:
目前我在dao曾有如下的注解配置:@ReadThroughSi ...
使用SSM注解做缓存操作
2008
-
10
-
20
客户端验证的极品--jQuery.validator
最近在做一个用户注册登录的页面,资料查寻过程中发现了一个非常不错的客户端验证的极品-jQuery.validate。
它是著名的JavaScript包jQuery的一个插件,其实它还有其它的一些插件应该都爽,有待慢慢来学习
官方地址:http://bassistance.de/jquery-plugins/jquery-plugin-validation/
jQuery用户手册:http://jquery.org.cn/visual/cn/index.xml
开发使用起来非常简单明了,
我的代码:
网上的资料有人说,它跟prototype包会有冲突,我还没有同时使用过,这点不是很清楚,但我是发现一个问题:
对于最小/大长度的验证方法,作者可能考虑到大家的命名习惯不同,同时做了minLength和minlength(maxLength和maxlength)方法,应该哪一个都是可以的,但对于用户Message来说,只能够定义针对minlength(maxlength),才能调用用户自定义的Message,
否则只是调用包的默认Message,但具体原因还没有查清楚。同时,这个插件提供了本地化的消息,但对于我这里初学者来说,怎么使用它还有待摸索!
它是著名的JavaScript包jQuery的一个插件,其实它还有其它的一些插件应该都爽,有待慢慢来学习
官方地址:http://bassistance.de/jquery-plugins/jquery-plugin-validation/
jQuery用户手册:http://jquery.org.cn/visual/cn/index.xml
开发使用起来非常简单明了,
我的代码:
- $(document).ready(function(){
- /* 设置默认属性 */
- $.validator.setDefaults({
- submitHandler: function(form) { form.submit(); }
- });
- // 中文字两个字节
- jQuery.validator.addMethod( "byteRangeLength" , 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[ 0 ] && length <= param[ 1 ] );
- }, "请确保输入的值在3-15个字节之间(一个中文字算2个字节)" );
- /* 追加自定义验证方法 */
- // 身份证号码验证
- jQuery.validator.addMethod( "isIdCardNo" , function(value, element) {
- return this .optional(element) || isIdCardNo(value);
- }, "请正确输入您的身份证号码" );
- // 字符验证
- jQuery.validator.addMethod( "userName" , function(value, element) {
- return this .optional(element) || /^[\u0391-\uFFE5\w]+$/.test(value);
- }, "用户名只能包括中文字、英文字母、数字和下划线" );
- // 手机号码验证
- jQuery.validator.addMethod( "isMobile" , 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( "isPhone" , function(value, element) {
- var tel = /^(\d{ 3 , 4 }-?)?\d{ 7 , 9 }$/g;
- return this .optional(element) || (tel.test(value));
- }, "请正确填写您的电话号码" );
- // 邮政编码验证
- jQuery.validator.addMethod( "isZipCode" , function(value, element) {
- var tel = /^[ 0 - 9 ]{ 6 }$/;
- return this .optional(element) || (tel.test(value));
- }, "请正确填写您的邮政编码" );
- $(regFrom).validate({
- /* 设置验证规则 */
- rules: {
- userName: {
- required: true ,
- userName: true ,
- byteRangeLength: [ 3 , 15 ]
- },
- password: {
- required: true ,
- minLength: 5
- },
- repassword: {
- required: true ,
- minLength: 5 ,
- equalTo: "#password"
- },
- question: {
- required: true
- },
- answer: {
- required: true
- },
- realName: {
- required: true
- },
- cardNumber: {
- isIdCardNo: true
- },
- mobilePhone: {
- isMobile: true
- },
- phone: {
- isPhone: true
- },
- email: {
- required: true ,
- email: true
- },
- zipCode: {
- isZipCode: true
- }
- },
- /* 设置错误信息 */
- messages: {
- userName: {
- required: "请填写用户名" ,
- byteRangeLength: "用户名必须在3-15个字符之间(一个中文字算2个字符)"
- },
- password: {
- required: "请填写密码" ,
- minlength: jQuery.format( "输入{0}." )
- },
- repassword: {
- required: "请填写确认密码" ,
- equalTo: "两次密码输入不相同"
- },
- question: {
- required: "请填写您的密码提示问题"
- },
- answer: {
- required: "请填写您的密码提示答案"
- },
- realName: {
- required: "请填写您的真实姓名"
- },
- email: {
- required: "请输入一个Email地址" ,
- email: "请输入一个有效的Email地址"
- }
- },
- /* 错误信息的显示位置 */
- errorPlacement: function(error, element) {
- error.appendTo( element.parent() );
- },
- /* 验证通过时的处理 */
- success: function(label) {
- // set as text for IE
- label.html( " " ).addClass( "checked" );
- },
- /* 获得焦点时不验证 */
- focusInvalid: false ,
- onkeyup: false
- });
- // 输入框获得焦点时,样式设置
- $( 'input' ).focus(function(){
- if ($( this ).is( ":text" ) || $( this ).is( ":password" ))
- $( this ).addClass( 'focus' );
- if ($( this ).hasClass( 'have_tooltip' )) {
- $( this ).parent().parent().removeClass( 'field_normal' ).addClass( 'field_focus' );
- }
- });
- // 输入框失去焦点时,样式设置
- $( 'input' ).blur(function() {
- $( this ).removeClass( 'focus' );
- if ($( this ).hasClass( 'have_tooltip' )) {
- $( this ).parent().parent().removeClass( 'field_focus' ).addClass( 'field_normal' );
- }
- });
- });
$(document).ready(function(){ /* 设置默认属性 */ $.validator.setDefaults({ submitHandler: function(form) { form.submit(); } }); // 中文字两个字节 jQuery.validator.addMethod("byteRangeLength", 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[0] && length <= param[1] ); }, "请确保输入的值在3-15个字节之间(一个中文字算2个字节)"); /* 追加自定义验证方法 */ // 身份证号码验证 jQuery.validator.addMethod("isIdCardNo", function(value, element) { return this.optional(element) || isIdCardNo(value); }, "请正确输入您的身份证号码"); // 字符验证 jQuery.validator.addMethod("userName", function(value, element) { return this.optional(element) || /^[\u0391-\uFFE5\w]+$/.test(value); }, "用户名只能包括中文字、英文字母、数字和下划线"); // 手机号码验证 jQuery.validator.addMethod("isMobile", 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("isPhone", function(value, element) { var tel = /^(\d{3,4}-?)?\d{7,9}$/g; return this.optional(element) || (tel.test(value)); }, "请正确填写您的电话号码"); // 邮政编码验证 jQuery.validator.addMethod("isZipCode", function(value, element) { var tel = /^[0-9]{6}$/; return this.optional(element) || (tel.test(value)); }, "请正确填写您的邮政编码"); $(regFrom).validate({ /* 设置验证规则 */ rules: { userName: { required: true, userName: true, byteRangeLength: [3,15] }, password: { required: true, minLength: 5 }, repassword: { required: true, minLength: 5, equalTo: "#password" }, question: { required: true }, answer: { required: true }, realName: { required: true }, cardNumber: { isIdCardNo: true }, mobilePhone: { isMobile: true }, phone: { isPhone: true }, email: { required: true, email: true }, zipCode: { isZipCode:true } }, /* 设置错误信息 */ messages: { userName: { required: "请填写用户名", byteRangeLength: "用户名必须在3-15个字符之间(一个中文字算2个字符)" }, password: { required: "请填写密码", minlength: jQuery.format("输入{0}.") }, repassword: { required: "请填写确认密码", equalTo: "两次密码输入不相同" }, question: { required: "请填写您的密码提示问题" }, answer: { required: "请填写您的密码提示答案" }, realName: { required: "请填写您的真实姓名" }, email: { required: "请输入一个Email地址", email: "请输入一个有效的Email地址" } }, /* 错误信息的显示位置 */ errorPlacement: function(error, element) { error.appendTo( element.parent() ); }, /* 验证通过时的处理 */ success: function(label) { // set as text for IE label.html(" ").addClass("checked"); }, /* 获得焦点时不验证 */ focusInvalid: false, onkeyup: false }); // 输入框获得焦点时,样式设置 $('input').focus(function(){ if($(this).is(":text") || $(this).is(":password")) $(this).addClass('focus'); if ($(this).hasClass('have_tooltip')) { $(this).parent().parent().removeClass('field_normal').addClass('field_focus'); } }); // 输入框失去焦点时,样式设置 $('input').blur(function() { $(this).removeClass('focus'); if ($(this).hasClass('have_tooltip')) { $(this).parent().parent().removeClass('field_focus').addClass('field_normal'); } }); });
网上的资料有人说,它跟prototype包会有冲突,我还没有同时使用过,这点不是很清楚,但我是发现一个问题:
对于最小/大长度的验证方法,作者可能考虑到大家的命名习惯不同,同时做了minLength和minlength(maxLength和maxlength)方法,应该哪一个都是可以的,但对于用户Message来说,只能够定义针对minlength(maxlength),才能调用用户自定义的Message,
否则只是调用包的默认Message,但具体原因还没有查清楚。同时,这个插件提供了本地化的消息,但对于我这里初学者来说,怎么使用它还有待摸索!
发表评论
-
关于Jquery和radio的若干
2012-08-04 15:29 1082如何通过Jquery获取radio的值 ... -
jquery radio/checkbox change 事件不能触发的问题
2012-03-05 10:13 8064需求 <input type="radio& ... -
用jQuery在IFRAME里取得父窗口的某个元素的值
2010-12-21 10:37 1665只好用DOM方法与jquery方法结合的方式实 ... -
jquery radio取值,checkbox取值,select取值,radio选中,checkbox选中,select选中,及其相关
2010-11-30 16:37 963jquery radio取值,checkbox取值 ... -
jquery 3种页面加载初始化的方法
2010-11-30 12:45 1409jquery 3种页面加载初始化的方法 2009-12- ... -
JQuery弹出层效果制作
2010-11-26 17:04 1811JQuery弹出层效果制作 2010-09-17 JQ ... -
jquery select option 操作相关知识
2010-11-26 15:21 2143jQuery 是一个非常强大的JS类库,现在越用觉得越好用 ...
相关推荐
Hibernate.jar包,Hibernate可以应用在任何使用JDBC的场合,包含 hibernate-commons-annotations-4.0.1.Final.jar hibernate-core-4.1.12.Final.jar hibernate-ehcache-4.1.12....hibernate-validator-5.0.1.Final.jar
spring-cloud-starter-gateway下的依赖hibernate-validator-5.0.3.Final.jar
使用hibernate-validator 进行校验的jar包,里面包括了基础hibernate-validator-5.0.0.CR2.jar hibernate-validator-annotation-processor-5.0.0.CR2.jar 之外,还包括了el-api-2.2.jar javax.el-2.2.4等项目必不可...
Hibernate Validator,作为Java世界中的一款强大且广泛使用的验证框架,极大地简化了应用中的数据验证过程。本文将深入探讨 Hibernate Validator 4.0.1.GA 版本,解析其核心功能与特性,以及在实际开发中的应用场景...
Hibernate Validator 是一个基于 Bean Validation 规范的实现,是 Hibernate 项目的一部分,主要用于进行 Java 对象的验证。它提供了丰富的约束注解和自定义验证逻辑,使得开发者能够在 Java 应用程序中轻松地进行...
`hibernate-validator-4.1.0.Final.jar`是核心库,包含了所有验证相关的类和接口,供项目中直接引用使用。 6. **Sources.jar**: `hibernate-validator-4.1.0.Final-sources.jar`包含了源代码,开发者可以查看...
hibernate-validator-4.2.0.Final.jar的下载
在没有联网的请求本地添加验证xml文件,添加验证XML文件的DTD
java运行依赖jar包
本主题将详细讲解`Hibernate Validator`以及与之相关的`validation-api-2.0.1.Final.jar`、`hibernate-validator-6.0.8.Final.jar`和`jboss-logging-3.3.2.Final.jar`这三个jar包的作用和重要性。 首先,`...
6. **源码分析(Source Code)**:提供的`commons-validator-1.3.1-src.gz`文件包含源代码,这使得开发者可以深入理解内部工作原理,进行定制化开发,或者排查可能出现的问题。 7. **API文档**:虽然没有直接给出,...
java运行依赖jar包
hibernate-validator-4.3.1.Final.jar jsr 303
hibernate-validator-6.0.9.Final.jar 供大家使用,希望能帮助到你们
这个压缩包“hibernate-validator-annotation-processor-4.3.1.final-sources.jar.zip”包含了Hibernate Validator注解处理器的源代码,版本号为4.3.1.Final,是理解其内部工作原理和自定义验证规则的重要资源。...
hibernate-validator-5.2.2.Final.jar , 供大家使用
这是数据校验的jar包,使用了hibernate框架的部分功能,上传上来以方便博客里面进行引用...需要用的朋友也可以下载使用
hibernate-validator-4.0.0.Beta1.jar
"validationEngine.jquery.css"是插件的样式文件,提供了丰富的样式定义,用于美化验证提示和错误消息的显示。通过自定义这些样式,你可以使验证反馈与网站设计风格保持一致,提升整体视觉效果。 6. **核心文件**...