`
royfu
  • 浏览: 13475 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

validationEngine参数详解

web 
阅读更多

validationEngine

  • ·jQuery v1.4.4+

注意事项:

1.演示版本为 v2.2.4;

2.v2.0 以下的版本参数并不完全通用;

对 validationEngine.jquery.css 文件进行修改,修改如下:

1.提示内容字体改为宋体;

2.去除中各浏览器的私有属性(各浏览器已经支持圆角和阴影,不再需要加私有属性)。

对 jquery.validationEngine.js 文件进行修改,修改如下:

1.将 312 行的 field.focus(); 注释掉,当有输入控件在 Table 内部时,验证会导致回到顶部的现象;

对 jquery.validationEngine-zh_CN.js 文件进行修改,修改如下:

1.修改部分提示文字;

2.增加两个对中文字符的验证规则:minSizeCN 和 maxSizeCN;

3.去除 "validate2fields": {"alertText":"* 请输入 HELLO"},

将以上两个JS文件进行合并

【options 参数说明】(可选)

名称 默认值 说明
validationEventTrigger "blur" 触发验证的事件,支持事件可参考 jQuery 的事件说明。

PS:如果希望只在表单提交时验证,可以设置为空。

scroll true 屏幕自动滚动到第一个验证不通过的位置
focusFirstField true 验证未通过时,是否给第一个不通过的控件获取焦点
promptPosition "topRight" 验证提示信息的位置,可设置为:"topRight", "bottomLeft", "centerRight", "bottomRight"
autoPositionUpdate false 是否自动调整提示层的位置
bindMethod "bind" 验证事件的绑定方式,可设置为:bind, live

PS:设置 live 似乎绑定事件无效,但是表单提交时能验证,建议不修改。[Demo]

binded false 是否已经绑定其他事件,设为 true 将不进行验证。
inlineAjax false  
ajaxFormValidation false 使用 Ajax 验证表单
ajaxFormValidationURL false 设置 Ajax 验证的 URL,默认使用 form 的 action 属性
ajaxValidCache {}  
onAjaxFormComplete $.noop 表单提交,Ajax 验证完成后的行为(Function)[Demo]
onBeforeAjaxFormValidation $.noop 表单提交验证规则通过后,Ajax 验证之前的行为(Function)[Demo]
onValidationComplete false 表单提交验证完成时的行为(Function)

可以得到两个参数:表单元素 和 验证结果(ture or false)[Demo]

onSuccess false 实时验证所有项目都通过时,发生的行为(Function)[Demo]
onFailure false 实时验证有未通过项目时,发生的行为(Function)[Demo]

PS:onSuccess 和 onFailure 在禁用实时验证时无效。例如 validationEventTrigger 设为空,或 bindMethod 设为 live

isOverflown false 表单是否在溢出滚动的元素内(即外部元素设置了 overflow:scroll)

PS:设置为 ture 后,提示内容的插入位置将更改为在验证的控件之前插入;

  此时需要在控件外层再套一个元素,并设置 class="inputContainer"

overflownDIV "" 设置了溢出滚动的元素,格式为 jQuery 的选择器。
showArrow true  
isError false  
InvalidFields []  

【使用方法】

载入 CSS 文件

<link rel="stylesheet" href="css/validationEngine.jquery.css">

载入 JavaScript 文件

<script src="js/jquery.validationEngine.js"></script> 
<script src="js/jquery.validationEngine-zh_CN.js"></script> 
<!-- 
jquery.validationEngine-zh_CN.js 该文件为提示文字和自定义验证规则; 
修改版已经将这两个文件合并,只需要载入 jquery.validationEngine.js; 
另外,jQuery 插件当然还需要载入 jQuery 库,版本需在 jQuery 1.4.4 以上。 
-->

给表单加上 ID

<form id="form_id" ...> 
... 
</form> 
<!-- ID 必须设置在 Form 标签中,否则无效 -->

给控件加上 ID 及 设置验证类型

<input id="test_1" name="test_1" type="text" class="validate[required]"> 
<input id="test_2" name="test_2" type="checkbox" class="validate[required]"> 
<textarea id="test_3" name="test_3" class="validate[required]"><textarea> 
<!-- 
validate[required] 表示必须填写 
控件必须要设置 ID,但并不要求与 Name 相同 
--> 

设置验证

// 直接调用 
$("#form_id").validationEngine(); 
 
// 自定义参数调用 
$("#form_id").validationEngine("attach",{ 
    promptPosition:"centerRight", 
    scroll:false 
}); 

【验证类型】

<!-- 
注:验证规则均写在 validate[] 中,如有多条规则,用英文逗号(,) 分割。 
例:validate[required,minSize[6],custom[onlyLetterNumber]] 
--> 
名称 示例 说明
required validate[required] 表示必填项
optional validate[optional] 表示可选项。若不输入,不要求必填,若有输入,则验证其是否符合要求。
dateRange[name] validate[dateRange[grp1]] 验证日期范围
dateTimeRange[name] validate[dateTimeRange[grp1]] 验证日期及时间范围
minSize[int] validate[minSize[6]] 最少输入字符数
maxSize[int] validate[maxSize[20]] 最多输入字符数
groupRequired[name] validate[groupRequired[grp2]] 群组中至少输入一项
min[int] validate[min[1]] 最小值(该项为数字的最小值,注意与 minSize 的区分)
max[int] validate[max[9999]] 最大值(该项为数字的最大值,注意与 maxSize 的区分)
past[date] validate[past[2012/12/20]] 日期必需在 date 或 date 的未来。date 格式可写作 YYYY/MM/DD、YYYY/M/D、YYYY-MM-DD、YYYY-M-D 或 now
future[date] validate[future[now]] 日期必须在 data 或 date 的过去。date 格式可写作 YYYY/MM/DD、YYYY/M/D、YYYY-MM-DD、YYYY-M-D 或 now
maxCheckbox[int] validate[maxCheckbox[2]] 最多选取的项目数(用于Checkbox)
minCheckbox validate[minCheckbox[2]] 最少选取的项目数(用于Checkbox)
equals validate[equals[id]] 当前控件值需与 id 这个控件的值相同
phone validate[custom[phone]] 验证电话号码
email validate[custom[email]] 验证 Email 地址
integer validate[custom[integer]] 验证整数
number validate[custom[number]] 验证数字
date validate[custom[date]] 验证日期,格式为 YYYY/MM/DD、YYYY/M/D、YYYY-MM-DD、YYYY-M-D
dateFormat validate[custom[dateFormat]] 验证日期格式,格式为 YYYY/MM/DD、YYYY/M/D、YYYY-MM-DD、YYYY-M-D
dateTimeFormat validate[custom[dateTimeFormat]] 验证日期及时间格式,格式为:YYYY/MM/DD hh:mm:ss AM|PM
ipv4 validate[custom[ipv4]] 验证 ipv4 地址
url validate[custom[url]] 验证 url 地址,需以 http://、https:// 或 ftp:// 开头
onlyNumberSp validate[custom[onlyNumberSp]] 只接受填数字和空格
onlyLetterSp validate[custom[onlyLetterSp]] 只接受填英文字母(大小写)和单引号(')
onlyLetterNumber validate[custom[onlyLetterNumber]] 只接受数字和英文字母
ajax validate[ajax[ajaxUserCallPhp]] 在验证规则中自定义

"ajaxUserCallPhp":{

"url":"phpajax/ajaxValidateFieldUser.php",

"extraData":"name=eric",

"alertTextOk":"* 此帐号名称可以使用",

"alertText":"* 此名称已被其他人使用",

"alertTextLoad":"* 正在确认帐号名称是否有其他人使用,请稍等。"

}

funcCall validate[funcCall[functionName]] 调用外部函数

【API 方法】

名称 示例 说明
attach $("#form_id").validationEngine("attach"); 注册表单验证事件
detach $("#form_id").validationEngine("detach"); 取消注册表单验证事件
validate alert($("#form_id").validationEngine("validate")); 验证表单,返回结果 true 或 false
validateField alert($("#form_id").validationEngine("validateField","#element_id")); 验证单个控件,返回结果 true 或 false
showPrompt $("#element_id").validationEngine("showPrompt","提示内容","load"); 在该元素上创建一个提示内容,3 种状态:"pass", "error", "load"
hidePrompt $("#element_id").validationEngine("hidePrompt"); 隐藏该元素的提示内容
hide $("#form_id").validationEngine("hide"); 关闭表单中的提示
hideAll $("#form_id").validationEngine("hideAll"); 关闭页面上的所有提示
updatePromptsPosition $("#form_id").validationEngine("updatePromptsPosition") 更新提示层的位置
分享到:
评论

相关推荐

    jquery表单验证插件validationEngine---个人修改

    **jQuery表单验证插件ValidationEngine详解** 在Web开发中,表单验证是必不可少的一环,它能够确保用户输入的数据符合预设的规则,从而提高数据的准确性和系统的稳定性。ValidationEngine是一款基于jQuery的强大的...

    jquery-ui-validation-Engine

    2. **初始化验证**:在文档加载完成后,调用 `.validationEngine('attach')` 方法,将验证功能绑定到目标表单。 3. **设置验证规则**:通过 `class` 或 `data-validation-engine` 属性为表单元素指定验证规则。例如...

    Demo_validation_engine校验框架使用

    **验证引擎(Demo_validation_engine)框架使用详解** 在软件开发中,验证是不可或缺的一个环节,它确保了输入数据的有效性和一致性。"Demo_validation_engine"是一个专门用于数据验证的框架,它提供了一种高效且灵活...

    jquery 表单验证

    &lt;link rel="stylesheet" type="text/css" href="validationEngine.jquery.css" /&gt; &lt;script src="jquery.validationEngine-en.js"&gt; &lt;script src="jquery.validationEngine.js"&gt; ``` 接下来,我们来了解如何初始化和...

    表单验证jquery插件

    &lt;link rel="stylesheet" type="text/css" href="path/to/validationEngine.jquery.css"&gt; ``` ## 3. 使用方法 ### 3.1 初始化验证 在页面加载完成后,使用 `$.validationEngine('attach')` 方法来初始化表单验证:...

    Jquery验证插件

    本文介绍的是一个名为`validationEngine`的jQuery表单验证插件。 #### 三、功能特点 - **美观的验证提示**:该插件提供了美观的Tooltip效果来显示验证结果,增强了用户交互体验。 - **广泛的浏览器兼容性**:虽然...

    jquery插件

    $("#formID").validationEngine(); }); ``` 以上代码表示在页面加载完成后,对id为"formID"的表单应用验证引擎。 自定义扩展时,开发者可以修改源代码,增加新的验证规则,或者调整现有规则的行为。此外,还可以...

    tomcat域名绑定.pdf

    ### Tomcat 5.5 配置:多域名绑定与虚拟目录详解 #### 一、背景介绍 在 Web 应用服务器领域,Apache Tomcat 是一个非常流行的 Java Servlet 容器,广泛应用于 Java Web 应用程序的部署。随着互联网的发展,单一...

    springMVC 注册登录源码

    8. **模板引擎(Template Engine)** 如果选择使用模板引擎如Thymeleaf,可以在服务器端动态生成HTML,增强用户体验。Thymeleaf语法直观且易于理解,能与SpringMVC无缝集成。 9. **错误处理(Error Handling)** ...

    Python库 | googleapputils-0.1-py3-none-any.whl

    1. **命令行参数处理**:`googleapputils.argparser` 提供了一个简单的命令行参数解析器,它可以替代Python标准库中的`argparse`,对于简单的用例更加轻量级。 2. **日志管理**:`googleapputils.logging_utils` ...

    tomcat域名绑定

    - 需要在DNS服务器中正确配置域名解析,确保域名能够正确指向Tomcat服务器的IP地址。 通过以上步骤,我们不仅能够实现多域名的绑定,还能够灵活地管理和部署网站。这对于网站开发者来说是一项非常实用且重要的技能...

    11基础 8:用户业务逻辑处理(1).md

    // 从HTTP消息体解析参数 // 参数校验 // 加密密码 // 在数据库中添加数据记录 // 返回结果 // 代码中通常会包含多个函数调用,如parseParams(), validateParams(), encryptPassword(), createUserInDB()等 *...

    jQuery-formValidator表单验证

    在HTML表单元素上添加data-validation-engine="validate"属性,并设置相应的配置参数(如:promptPosition、validationEvent等),如下所示: ```html &lt;form id="myForm" data-validation-engine="validate...

    dwr2chm格式的帮助文档

    《DWR技术详解——基于dwr2chm格式的帮助文档》 DWR(Direct Web Remoting)是一种在Java服务器端和JavaScript客户端之间进行双向通信的技术,它允许开发者在Web应用程序中实现类似桌面应用的交互体验。DWR的核心是...

    play框架手册

    Localised validation messages 局部验证消息 - 55 - 验证消息参数 - 55 - 定制局部验证消息 - 56 - 定制teral(非局部)验证消息 - 57 - 在模板里显示验证错误消息 - 57 - 验证注释 - 60 - 验证复杂对象 - 60 - 内...

    DWR配置介绍

    ### DWR配置与使用详解 #### 一、DWR简介 DWR,全称为Direct Web Remoting,是一种专为Java开发者设计的AJAX框架。它通过简化JavaScript与Java后端服务之间的交互,使得前端开发人员能够如同调用本地JavaScript...

    兵河五四V0.60源码-C++代码类资源

    1. **Engine Class**:这是核心的象棋引擎类,实现了UCI协议的命令处理,包含搜索算法(如Alpha-Beta剪枝,PVS,Quiescence Search)和评估函数,用于计算棋局评分。 2. **Chess Board Representation**:棋盘状态...

Global site tag (gtag.js) - Google Analytics