代码
$.extend($.fn.validatebox.defaults.rules, {
CHS: {
validator: function (value, param) {
return /^[\u0391-\uFFE5]+$/.test(value);
},
message: '请输入汉字'
},
ZIP: {
validator: function (value, param) {
return /^[1-9]\d{5}$/.test(value);
},
message: '邮政编码不存在'
},
QQ: {
validator: function (value, param) {
return /^[1-9]\d{4,10}$/.test(value);
},
message: 'QQ号码不正确'
},
mobile: {
validator: function (value, param) {
return /^((\(\d{2,3}\))|(\d{3}\-))?13\d{9}$/.test(value);
},
message: '手机号码不正确'
},
loginName: {
validator: function (value, param) {
return /^[\u0391-\uFFE5\w]+$/.test(value);
},
message: '登录名称只允许汉字、英文字母、数字及下划线。'
},
safepass: {
validator: function (value, param) {
return safePassword(value);
},
message: '密码由字母和数字组成,至少6位'
},
equalTo: {
validator: function (value, param) {
return value == $(param[0]).val();
},
message: '两次输入的字符不一至'
},
number: {
validator: function (value, param) {
return /^\d+$/.test(value);
},
message: '请输入数字'
},
idcard: {
validator: function (value, param) {
return idCard(value);
},
message:'请输入正确的身份证号码'
}
});
/* 密码由字母和数字组成,至少6位 */
var safePassword = function (value) {
return !(/^(([A-Z]*|[a-z]*|\d*|[-_\~!@#\$%\^&\*\.\(\)\[\]\{\}<>\?\\\/\'\"]*)|.{0,5})$|\s/.test(value));
}
var idCard = function (value) {
if (value.length == 18 && 18 != value.length) return false;
var number = value.toLowerCase();
var d, sum = 0, v = '10x98765432', w = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2], a = '11,12,13,14,15,21,22,23,31,32,33,34,35,36,37,41,42,43,44,45,46,50,51,52,53,54,61,62,63,64,65,71,81,82,91';
var re = number.match(/^(\d{2})\d{4}(((\d{2})(\d{2})(\d{2})(\d{3}))|((\d{4})(\d{2})(\d{2})(\d{3}[x\d])))$/);
if (re == null || a.indexOf(re[1]) < 0) return false;
if (re[2].length == 9) {
number = number.substr(0, 6) + '19' + number.substr(6);
d = ['19' + re[4], re[5], re[6]].join('-');
} else d = [re[9], re[10], re[11]].join('-');
if (!isDateTime.call(d, 'yyyy-MM-dd')) return false;
for (var i = 0; i < 17; i++) sum += number.charAt(i) * w[i];
return (re[2].length == 9 || number.charAt(17) == v.charAt(sum % 11));
}
var isDateTime = function (format, reObj) {
format = format || 'yyyy-MM-dd';
var input = this, o = {}, d = new Date();
var f1 = format.split(/[^a-z]+/gi), f2 = input.split(/\D+/g), f3 = format.split(/[a-z]+/gi), f4 = input.split(/\d+/g);
var len = f1.length, len1 = f3.length;
if (len != f2.length || len1 != f4.length) return false;
for (var i = 0; i < len1; i++) if (f3[i] != f4[i]) return false;
for (var i = 0; i < len; i++) o[f1[i]] = f2[i];
o.yyyy = s(o.yyyy, o.yy, d.getFullYear(), 9999, 4);
o.MM = s(o.MM, o.M, d.getMonth() + 1, 12);
o.dd = s(o.dd, o.d, d.getDate(), 31);
o.hh = s(o.hh, o.h, d.getHours(), 24);
o.mm = s(o.mm, o.m, d.getMinutes());
o.ss = s(o.ss, o.s, d.getSeconds());
o.ms = s(o.ms, o.ms, d.getMilliseconds(), 999, 3);
if (o.yyyy + o.MM + o.dd + o.hh + o.mm + o.ss + o.ms < 0) return false;
if (o.yyyy < 100) o.yyyy += (o.yyyy > 30 ? 1900 : 2000);
d = new Date(o.yyyy, o.MM - 1, o.dd, o.hh, o.mm, o.ss, o.ms);
var reVal = d.getFullYear() == o.yyyy && d.getMonth() + 1 == o.MM && d.getDate() == o.dd && d.getHours() == o.hh && d.getMinutes() == o.mm && d.getSeconds() == o.ss && d.getMilliseconds() == o.ms;
return reVal && reObj ? d : reVal;
function s(s1, s2, s3, s4, s5) {
s4 = s4 || 60, s5 = s5 || 2;
var reVal = s3;
if (s1 != undefined && s1 != '' || !isNaN(s1)) reVal = s1 * 1;
if (s2 != undefined && s2 != '' && !isNaN(s2)) reVal = s2 * 1;
return (reVal == s1 && s1.length != s5 || reVal > s4) ? -10000 : reVal;
}
};
页面中要引入jquery.js 和 easyui.min.js
html 代码中使用如下
<table class="grid" id="uiform">
<tr><td>登录名:</td><td><input required="true" id="txtUsername" type="text" class="txt03" /></td><td>真实姓名:</td><td><input id="txtTruename" validType="CHS" required="true" type="text" class="txt03" /></td></tr>
<tr><td>登录密码:</td><td><input validType="safepass" required="true" id="txtPassword" name="password" type="password" class="txt03" /></td><td>Email:</td><td><input id="txtEmail" name="email" validType="email" type="text" class="txt03" /></td></tr>
<tr><td>身份证号:</td><td><input validType="idcard" id="txtIdcard" name="idcard" type="text" class="txt03" /></td><td>QQ:</td><td><input validType="QQ" id="txtQq" name="qq" type="text" class="txt03" /></td></tr>
<tr><td>手机:</td><td><input validType="mobile" id="txtMobile" name="mobile" type="text" class="txt03" /></td><td>电话:</td><td><input id="txtTel" name="tel" type="text" class="txt03" /></td></tr>
<tr><td>家庭住址:</td><td colspan="3"><input validType="equalTo[txtMobile]" style="width:80%" id="txtHomeaddr" name="homeaddr" type="text" class="txt03" /></td></tr>
<tr><td>备注:</td><td colspan="3"> <input type="text" style="width:80%" class="txt03" id="txtRemark"></textarea></td></tr>
<tr><td> </td><td colspan="3"><input id="Checkbox1" type="checkbox" /><label>超级管理员</label> <input id="Checkbox2" type="checkbox" /><label>禁用</label></td></tr>
</table>
这一段JS 是必不可少的
$(function(){
$('#uiform input').each(function () {
if ($(this).attr('required') || $(this).attr('validType'))
$(this).validatebox();
})
});
这样就ok了
如果在提交时验证表单有没有通过验证,则可使用下面的代码
var flag = true;
$('#uiform input').each(function () {
if ($(this).attr('required') || $(this).attr('validType')) {
if (!$(this).validatebox('isValid')) {
flag = false;
return;
}
}
})
if (flag)
alert('验证通过!');
else
alert('验证失败!');
分享到:
相关推荐
在EasyUI中,validate.js 是一个关键组件,主要用于表单验证。它提供了一系列的校验规则,帮助开发者确保用户输入的数据符合预设的规范,从而提高应用的安全性和用户体验。 在EasyUI的validate.js文件中,包含了一...
然而,在实际操作中,我们可能会遇到`easyui form validate`方法总是返回`false`的问题,这可能导致表单无法正常提交。本文将深入探讨这个问题的原因并提供相应的解决方案。 ### 问题分析 1. **类库冲突**: 问题...
例如,我们可以通过`$('#formId').form('validate')`来验证表单数据,如果所有字段都符合规则,该方法将返回`true`。此外,`datagrid`组件是用于展示数据的,它支持分页、排序和过滤功能,开发者可以通过`reloadGrid...
- **第三方插件兼容**: 虽然EasyUI本身已经非常强大,但开发者仍可结合其他jQuery插件如validate、form等增强功能。 10. **API文档**: - **.chm文件**: 提供的jQuery EasyUI 1.4 版 API 中文版 .chm文件是离线...
`$.fn.form` 的 `validate` 方法可用于执行这些验证。 5. **事件处理**:登录按钮的点击事件通常会触发一系列处理,比如收集表单数据、发送 AJAX 请求到服务器验证用户身份。EasyUI 允许通过 `onsubmit` 或 `...
return $("#form1").form('validate'); ``` - **解释**:这行代码用于在提交表单之前进行整体验证,如果所有验证均通过,则返回`true`,否则返回`false`并显示相应的错误信息。 #### 五、总结 通过上述示例可以...
EasyUI 是一个基于 jQuery 的前端框架,主要用于简化网页界面开发,提供了一系列的组件,如对话框、表单、树形菜单、数据网格等。在"easyui使用的js文件"这个主题下,我们将深入探讨EasyUI的核心JavaScript文件及其...
- 使用 `$(selector).form('validate')` 验证表单数据。 API 文档会详细介绍每个组件的配置选项、方法、事件和示例代码,便于开发者查阅和参考。同时,EasyUI的组件设计遵循一致的命名规则和编程模式,使得学习和...
return $(this).form('validate'); // 验证表单 }, success: function(data){ var json = eval('(' + data + ')'); if (json.success){ // 处理成功情况 } else { // 处理失败情况 } } }); ``` 此外,...
- `.form('validate')`:验证表单数据。 - `.tree('expand', index)`:展开树形视图的某个节点。 - `.button('disable')`:禁用按钮。 五、主题与定制 jQuery EasyUI 提供了多种预定义的主题,如默认的 `easyui`、...
在IT行业中,前端开发是构建用户界面的关键环节,而EasyUI和jQuery是两个非常流行的JavaScript库,它们大大简化了Web应用程序的开发。本教程将深入探讨如何结合EasyUI实现用户验证,以及如何扩展jQuery控件验证功能...
return $(this).form('validate'); }, success: function(data){ var json = eval('(' + data + ')'); if (json.success){ // 成功处理逻辑 } else { // 失败处理逻辑 } } }); ``` ### 4. 自定义主题和...
- **API 方法**:例如对话框的 open() 和 close() 方法,表格的 reload() 方法用于重新加载数据,表单的 validate() 方法进行验证等。 - **动态操作**:可以动态添加、删除或修改组件的状态,比如动态添加表格行...
EasyUI 支持 HTML5,允许对 HTML 标签进行增强,并提供丰富的组件库,如 Layout、Window、Tabs、Dialog、Messager、DataGrid、Tree、Form、Validate、Button等,极大地简化了网页开发的过程。 使用 EasyUI 的步骤...
`form`组件提供了`validate`方法进行表单验证,确保输入的数据符合要求。提交表单后,通常会通过AJAX向服务器发送POST请求,处理数据的新增或更新。 此外,为了实现与后台的数据交互,我们需要使用JSON格式来传输...
API 文档详细列出了每个组件的属性、方法和事件,如`dialog('open')`打开对话框,`grid('load', data)`加载表格数据,`form('validate')`验证表单数据等。通过这些API,开发者可以精确控制组件的行为。 4. **主题...
通过`$.fn.form`扩展jQuery对象,实现了如validate(验证)、submit(提交)等方法。表单的验证功能是通过配置 validateRules 和 validateMessages 实现的,源码中详细定义了各种验证规则的实现,如required、length...
### easyui用户手册知识点解析 #### 一、easyUI简介 **easyUI**是一款功能强大的JavaScript框架,专门用于简化Web应用程序的开发流程。它提供了一系列丰富的用户界面组件,如按钮、菜单、数据网格等,使得开发者...