要实现的功能:在做添加学生信息的时候,利用easyui的验证功能判断 学号是否重复和学号只能为数字

最终效果如下图:

但在做这个的过程中,遇到了一系列的问题:

扩展validatebox的验证方法,最开始的验证代码如下:

  1. //学号格式只能为数字 ****//这里没有问题****
  2. number: {//value值为文本框中的值
  3. validator: function (value) {
  4. var reg = /^[0-9]*$/;
  5. return reg.test(value);
  6. },
  7. message: '学号格式不正确.'
  8. },
  1. //验证学号不能重复
  2. snumber: {
  3. //param参数为textarea的id值
  4. validator: function (value, param) {
  5. //将从后台获取的json数据先放入textarea,再获取出来后解析成数组
  6. var snumbers = $.parseJSON($(param)[0].val());
  7. for(var i=0;i < snumbers.length;i++){
  8. if(value == snumbers[i]){ //如果学号有重复返回false
  9. return false;
  10. }
  11. }
  12. return true;
  13. }

在这里先只做学号重复验证,因为有其它一些问题,也遇到了一些问题:

表单开始是这样写的,validType属性写在data-options属性里:

  1. <input id="addSnumber" class="easyui-textbox" style="width: 200px; height: 30px;" type="text" name="snumber" data-options="required:true,validType:'snumber[#snumbers]', missingMessage:'请输入学号'" />
  2. <textarea id="snumbers" style="display: none"></textarea>

这里就有一个问题就是:这样写Firebug会报错,因为#snumbers需要用引号引起来,但是直接加引号会出错,这里相当于是三重引号,网上查了很多资料,有的用转义,都行不通,我猜想这里是easyui解析的问题,除非更改easyui的源码。有大神知道的还请不吝赐教。

然后将validType属性放在外面,验证成功,如下:

  1. <input id="addSnumber" validType="snumber['#snumbers']" class="easyui-textbox" style="width: 200px; height: 30px;" type="text" name="snumber" data-options="required:true, missingMessage:'请输入学号'" />
  2. <textarea id="snumbers" style="display: none"></textarea>

然后新的问题又出现了,如何把学号格式验证加进去?

我是这样写的,不成功,感觉还是三重引号的问题,Firebug报错,各种方法都试了,无效:

  1. <input id="addSnumber" validType="['snumber['#snumbers']', 'number']" class="easyui-textbox" style="width: 200px; height: 30px;" type="text" name="snumber" data-options="required:true, missingMessage:'请输入学号'" />
  2. <textarea id="snumbers" style="display: none"></textarea>

********************************************************先告一段落****************************************************************

然后我试了另一种方式,动态加载easyui控件,但是两个验证放在一起还是会有同样的问题,在这里我肯定是easyui解析的问题了,也就不纠结了。

这里遇到两个问题,一个是怎么将ajax返回来的数据放进validType属性中,就是不用另一个textarea来存数据,未解决......求指导

第二个是动态设置easyui控件无效的问题,简单说下,代码如下:

  1. <input id="addSnumber" style="width: 200px; height: 30px;" type="text" name="snumber" />
  1. //设置easyui控件
  2. $("#addSnumber").attr("class", "easyui-textbox");
  3. //设置验证属性
  4. $("#addSnumber").attr("validType","snumber['#snumber']");

上面这样在jQuery里设置easyui控件后,没有效果,后来百度了下,动态添加easy控件后需要重新渲染下,如下:

  1. //设置easyui控件
  2. $("#addSnumber").attr("class", "easyui-textbox");
  3. //设置验证属性
  4. $("#addSnumber").attr("validType","snumber['#snumber']");
  5. //解析所有页面
  6. $.parser.parse();

这样就可以了;但是查看easyui的api后发现可以只解析某个dom元素。

下面这段代码达不到效果:

  1. //设置easyui控件
  2. $("#addSnumber").attr("class", "easyui-textbox");
  3. //设置验证属性
  4. $("#addSnumber").attr("validType","snumber['#snumber']");
  5. //解析指定元素
  6. $.parser.parse($("#addSnumber"));

后经百度后得知:

parser只渲染$("#addSnumber")的子孙元素,并不包括$("#addSnumber")自身,而它的子孙元素并不包含任何Easyui支持的控件class,所以这个地方就得不到想要的效果了。

参考:jQuery EasyUI动态添加控件或者ajax加载页面后不能自动渲染问题的解决方法

所以想要渲染单个元素要像下面这样写:

  1. //设置easyui控件
  2. $("#addSnumber").attr("class", "easyui-textbox");
  3. //设置验证属性
  4. $("#addSnumber").attr("validType","snumber['#snumber']");
  5. //解析指定元素,找它的父元素
  6. $.parser.parse($("#addSnumber").parent());

******************************************************OK*********************************************

回到之前的问题,验证学号不能重复和学号格式。

最后网上查阅了各种资料,发现我的思路不行,因为我是先将所有学号加载到客户端再验证,但这样有一个问题,如果多个用户在这期间添加了学号就有可能导致重复。

所以最后将获取所有学号的操作放到验证函数里,如下:

  1. //验证学号不能重复
  2. snumber: {
  3. validator: function (value) {
  4. var flag = true;
  5. $.ajax({
  6. type: "post",
  7. async: false,
  8. url: "/sims/StudentServlet?method=AllSNumber",
  9. success: function(data){//在验证函数里加载数据,加载过来后判断输入的值
  10. var snumbers = $.parseJSON(data);
  11. for(var i=0;i < snumbers.length;i++){
  12. if(value == snumbers[i]){
  13. flag = false;
  14. break;
  15. }
  16. }
  17. }
  18. });
  19.  
  20. return flag;
  21. },
  22. message: '学号重复'
  23. },

这样写的好处是:可以实时加载数据来判断,在提交表单时也会再加载数据来判断一次,而且不需要传入参数,就不会再有三重引号的问题了;但有一个缺点就是会很多次请求数据库,服务器资源消耗大。

提交表单时加入下面这句,验证表单:

  1. //验证表单
  2. var validate = $("#editStuForm").form("validate");
  3. if(!validate){
  4.   $.messager.alert("消息提醒","请检查你输入的数据!","warning");
  5.   return;
  6. } else{
  7.   //提交
  8. }

这里有另一个问题,表单代码如下:

  1. <input id="addSnumber" class="easyui-textbox" validType="'snumber', 'number'" style="width: 200px; height: 30px;" type="text" name="snumber" data-options="required:true, missingMessage:'请输入学号'" />

这里将validType属性放在data-options外面后,不能验证,Firebug会报错!!!

最后将其放到data-options里面:

  1. <input id="addSnumber" class="easyui-textbox" style="width: 200px; height: 30px;" type="text" name="snumber" data-options="required:true, validType:['snumber', 'number'], missingMessage:'请输入学号'" />

OK,都行了,两个验证都可以了!!!

总结:easyui验证重复和格式,多重验证

  1. //学号格式只能为数字
  2. number: {//value值为文本框中的值
  3. validator: function (value) {
  4. var reg = /^[0-9]*$/;
  5. return reg.test(value);
  6. },
  7. message: '学号格式不正确.'
  8. },
  9. //验证学号不能重复
  10. snumber: {
  11. validator: function (value) {
  12. var flag = true;
  13. $.ajax({
  14. type: "post",
  15. async: false,
  16. url: "/sims/StudentServlet?method=AllSNumber",
  17. success: function(data){//在验证函数里加载数据,加载过来后判断输入的值
  18. var snumbers = $.parseJSON(data);
  19. for(var i=0;i < snumbers.length;i++){
  20. if(value == snumbers[i]){
  21. flag = false;
  22. break;
  23. }
  24. }
  25. }
  26. });
  27.  
  28. return flag;
  29. },
  30. message: '学号重复'
  31. },
  1. <tr>
  2. <td>学号:</td>
  3. <td>
  4. <input id="addSnumber" class="easyui-textbox" style="width: 200px; height: 30px;" type="text" name="snumber" data-options="required:true, validType:['snumber', 'number'], missingMessage:'请输入学号'" />
  5. </td>
  6. </tr>

最终效果如下图:

OK!!!

大多都是自己多次尝试总结的,很多东西还不明白其中的原理,我想应该是easyui.min.js的问题。如果有哪些地方不对,而且还有些问题不懂,望大神不吝赐教!!

  1.  

easyui表单多重验证,动态设置easyui控件的更多相关文章

  1. 基于Extjs的web表单设计器 第四节——控件拖放

    接着上一节介绍控件拖放的设计. 通过前面的介绍知道,我们的区域类型的容器控件有三种:Card.Table.Mixed. Card 可以支持几乎所有的常用控件,包括:文本TextField.多文本Tex ...

  2. easyui表单提交验证form

    方式一,不需要考虑jquery.easyui.min.js版本 <script> $(function () { //针对 设置 novalidate:true $('.validateb ...

  3. EasyUI表单验证,自定义插件验证,自定义js插件验证,远程验证,常见手机号,中英文,qq等验证规则验证

     { field : 'startPort', title : "起始端口", editor: "text", width : 50, editor: { ...

  4. easyUI表单验证

    1.重写easyui中的 $.extend($.fn.validatebox.defaults.rules, { }) 2.长度重写的方式 1 $.extend($.fn.validatebox.de ...

  5. EasyUI加zTree使用解析 easyui修改操作的表单回显方法 验证框提交表单前验证 datagrid的load方法

    带参提交一次查询,从服务器加载新数据.这是一个神奇的方法 $('#dg').datagrid('load',{ code: '01', name: 'name01' }); easyui修改操作的回显 ...

  6. 雷林鹏分享:jQuery EasyUI 表单 - 表单验证

    jQuery EasyUI 表单 - 表单验证 本教程将向您展示如何验证一个表单.easyui 框架提供一个 validatebox 插件来验证一个表单.在本教程中,我们将创建一个联系表单,并应用 v ...

  7. ajax提交表单无法验证easyui的验证选项(比如required等)

    在实际开发中,遇到ajax方式提交表单没法验证easyui的验证选项,这对实际用户体验造成了很大的困扰.当然,这也是理所当然的事情.   解决办法:使用jquery中ajax的beforeSend事件 ...

  8. easyUI表单基础知识

    easyUI创建异步提交表单 我们创建一个带有 name.email 和 phone 字段的表单.通过使用 easyui 表单(form)插件来改变表单(form)为 ajax 表单(form).表单 ...

  9. easyui表单插件-包括日期时控件-列表

    ← jQuery EasyUI 表单插件 – Numberspinner 数值微调器 jQuery EasyUI 表单插件 - Timespinner 时间微调器  jQuery EasyUI 插件 ...

随机推荐

  1. 《30天自制操作系统》18_day_学习笔记

    harib15a: 到这里为止,我们已经能实现窗口的切换了.我们发现所有的窗口都有光标闪烁,而我们只希望可以接受输入的窗口有光标闪烁.这里我们先来修改任务A中的光标闪烁,当按下TAB时,如果让A不现实 ...

  2. mysql的一些基本操作语句

    -- 创建一个php2016的数据库create database php2016;-- 查看数据库的创建创建语句show create database php2016;-- 指定默认的操作数据库u ...

  3. paper 106:图像增强方面的介绍

    图像增强是从像素到像素的操作,是以预定的方式改变图像的灰度直方图.有时又称为对比度增强,灰度变换.点运算不可能改变图像内的空间关系,输出像素的灰度值由输入像素的值决定.其作用: 对比度增强:扩展感兴趣 ...

  4. jSP-13-其他

    1.    JAVAEE Ø  Java平台版本 Java平台有3个版本: 适用于小型设备和智能卡的JavaME (Java Platform Micro Edition,Java 微型版) 适用于桌 ...

  5. 在linux中访问virtualbox的共享文件夹

    1.在客户机里需要安装Virtualbox的增强功能. 2.使用virtualbox的图形界面设置好共享文件夹. 3.假设你设置的共享文件夹的名称是 share,使用如下命令在客户机的linux系统中 ...

  6. 解除SQL对组件"Ad Hoc Distributed Queries"的"STATEMENT'OpenRowset OpenDatasource"的访问

      SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATEMENT'OpenRowset/OpenDatasource' 的访问,因为此组件已作为 ...

  7. Dundas控件的X轴字体竖排版

    dundas 坐标轴的问题 x轴的值怎么让他竖排显示?我晓得dundas可以旋转显示,但是不是我要的效果 如下 ---------------------------------------  第   ...

  8. RunTime的一些用法

    RunTime的一些用法   RunTime简介 RunTime简称运行时.OC就是运行时机制,其中最主要的是消息机制 对于OC来说,在编译的时候并不能决定真正调用哪个函数,只有真正运行时才会根据函数 ...

  9. Java虚拟机学习(2):垃圾收集算法

    跟踪收集器 跟踪收集器采用的为集中式的管理方式,全局记录对象之间的引用状态,执行时从一些列GC  Roots的对象做为起点,从这些节点向下开始进行搜索所有的引用链,当一个对象到GC  Roots 没有 ...

  10. Worker Thread

    http://www.codeproject.com/Articles/552/Using-Worker-Threads Introduction Worker threads are an eleg ...