
但在做这个的过程中,遇到了一系列的问题:
扩展validatebox的验证方法,最开始的验证代码如下:
//学号格式只能为数字****//这里没有问题****number: {//value值为文本框中的值validator: function (value) {var reg = /^[0-9]*$/;return reg.test(value);},message: "学号格式不正确."},//验证学号不能重复snumber: { //param参数为textarea的id值 validator: function (value, param) { //将从后台获取的json数据先放入textarea,再获取出来后解析成数组 var snumbers = $.parseJSON($(param)[0].val()); for(var i=0;i < snumbers.length;i++){ if(value == snumbers[i]){ //如果学号有重复返回false return false; } } return true; }在这里先只做学号重复验证,因为有其它一些问题,也遇到了一些问题:<input id="addSnumber" class="easyui-textbox" style="width: 200px; height: 30px;" type="text" name="snumber" data-options="required:true,validType:"snumber[#snumbers]", missingMessage:"请输入学号"" /><textarea id="snumbers" style="display: none"></textarea>这里就有一个问题就是:这样写Firebug会报错,因为#snumbers需要用引号引起来,但是直接加引号会出错,这里相当于是三重引号,网上查了很多资料,有的用转义,都行不通,我猜想这里是easyui解析的问题,除非更改easyui的源码。有大神知道的还请不吝赐教。
<input id="addSnumber" validType="snumber["#snumbers"]" class="easyui-textbox" style="width: 200px; height: 30px;" type="text" name="snumber" data-options="required:true, missingMessage:"请输入学号"" /><textarea id="snumbers" style="display: none"></textarea>然后新的问题又出现了,如何把学号格式验证加进去?
<input id="addSnumber" validType="["snumber["#snumbers"]", "number"]" class="easyui-textbox" style="width: 200px; height: 30px;" type="text" name="snumber" data-options="required:true, missingMessage:"请输入学号"" /><textarea id="snumbers" style="display: none"></textarea>然后我试了另一种方式,动态加载easyui控件,但是两个验证放在一起还是会有同样的问题,在这里我肯定是easyui解析的问题了,也就不纠结了。
<input id="addSnumber" style="width: 200px; height: 30px;" type="text" name="snumber" />//设置easyui控件$("#addSnumber").attr("class", "easyui-textbox");//设置验证属性$("#addSnumber").attr("validType","snumber["#snumber"]");上面这样在jQuery里设置easyui控件后,没有效果,后来百度了下,动态添加easy控件后需要重新渲染下,如下://设置easyui控件$("#addSnumber").attr("class", "easyui-textbox");//设置验证属性$("#addSnumber").attr("validType","snumber["#snumber"]");//解析所有页面$.parser.parse();这样就可以了;但是查看easyui的api后发现可以只解析某个dom元素。
//设置easyui控件$("#addSnumber").attr("class", "easyui-textbox");//设置验证属性$("#addSnumber").attr("validType","snumber["#snumber"]");//解析指定元素$.parser.parse($("#addSnumber"));后经百度后得知:
//设置easyui控件$("#addSnumber").attr("class", "easyui-textbox");//设置验证属性$("#addSnumber").attr("validType","snumber["#snumber"]");//解析指定元素,找它的父元素$.parser.parse($("#addSnumber").parent());回到之前的问题,验证学号不能重复和学号格式。
//验证学号不能重复snumber: {validator: function (value) {var flag = true;$.ajax({type: "post",async: false,url: "/sims/StudentServlet?method=AllSNumber",success: function(data){//在验证函数里加载数据,加载过来后判断输入的值var snumbers = $.parseJSON(data);for(var i=0;i < snumbers.length;i++){if(value == snumbers[i]){flag = false;break;}}}});return flag;},message: "学号重复"},这样写的好处是:可以实时加载数据来判断,在提交表单时也会再加载数据来判断一次,而且不需要传入参数,就不会再有三重引号的问题了;但有一个缺点就是会很多次请求数据库,服务器资源消耗大。//验证表单var validate = $("#editStuForm").form("validate");if(!validate){ $.messager.alert("消息提醒","请检查你输入的数据!","warning"); return;} else{ //提交}这里有另一个问题,表单代码如下:<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会报错!!!
<input id="addSnumber" class="easyui-textbox" style="width: 200px; height: 30px;" type="text" name="snumber" data-options="required:true, validType:["snumber", "number"], missingMessage:"请输入学号"" />OK,都行了,两个验证都可以了!!!
//学号格式只能为数字number: {//value值为文本框中的值validator: function (value) {var reg = /^[0-9]*$/;return reg.test(value);},message: "学号格式不正确."},//验证学号不能重复snumber: {validator: function (value) {var flag = true;$.ajax({type: "post",async: false,url: "/sims/StudentServlet?method=AllSNumber",success: function(data){//在验证函数里加载数据,加载过来后判断输入的值var snumbers = $.parseJSON(data);for(var i=0;i < snumbers.length;i++){if(value == snumbers[i]){flag = false;break;}}}});return flag;},message: "学号重复"},<tr><td>学号:</td><td> <input id="addSnumber" class="easyui-textbox" style="width: 200px; height: 30px;" type="text" name="snumber" data-options="required:true, validType:["snumber", "number"], missingMessage:"请输入学号"" /></td></tr>最终效果如下图:

OK!!!
大多都是自己多次尝试总结的,很多东西还不明白其中的原理,我想应该是easyui.min.js的问题,还需要继续学习,希望这篇文章可以帮到大家。