亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Jquery插件easyUi實現表單驗證示例

2019-11-20 11:00:38
字體:
來源:轉載
供稿:網友

要實現的功能:在做添加學生信息的時候,利用easyui的驗證功能判斷 學號是否重復和學號只能為數字

最終效果如下圖:

但在做這個的過程中,遇到了一系列的問題:

擴展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; }

在這里先只做學號重復驗證,因為有其它一些問題,也遇到了一些問題:

表單開始是這樣寫的,validType屬性寫在data-options屬性里:

<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的源碼。有大神知道的還請不吝賜教。
然后將validType屬性放在外面,驗證成功,如下:

<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>

然后新的問題又出現了,如何把學號格式驗證加進去?

我是這樣寫的,不成功,感覺還是三重引號的問題,Firebug報錯,各種方法都試了,無效:

<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解析的問題了,也就不糾結了。

這里遇到兩個問題,一個是怎么將ajax返回來的數據放進validType屬性中,就是不用另一個textarea來存數據,未解決......求指導

第二個是動態設置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"));

后經百度后得知:

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

 所以想要渲染單個元素要像下面這樣寫:

//設置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會報錯?。?!

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

<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驗證重復和格式,多重驗證

//學號格式只能為數字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的問題,還需要繼續學習,希望這篇文章可以幫到大家。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩美女激情视频| 欧美刺激性大交免费视频| 色婷婷综合久久久久| 色综合天天综合网国产成人网| 亚洲欧美中文在线视频| 久久久久亚洲精品成人网小说| 97激碰免费视频| 久久精品国产成人| 久久99久久99精品免观看粉嫩| 97avcom| 久久久国产一区二区三区| 91精品视频免费看| 91美女福利视频高清| 精品美女久久久久久免费| 国内精品久久久久伊人av| 色综合久久88色综合天天看泰| 亚洲精品自拍视频| 久久夜精品va视频免费观看| 91热福利电影| 欧美极品少妇xxxxⅹ喷水| 黄网动漫久久久| 国产免费久久av| 欧美激情视频一区二区三区不卡| 亚洲天堂av电影| 午夜精品福利在线观看| 久久精品成人欧美大片古装| www.亚洲人.com| 日韩精品极品在线观看播放免费视频| 亚洲欧美自拍一区| 96pao国产成视频永久免费| 欧美亚洲国产日韩2020| 国产日韩在线播放| 亚洲精品一区中文| 国产一级揄自揄精品视频| 欧美日韩午夜激情| 91精品综合视频| 国产精品久久久久久av福利软件| 超碰97人人做人人爱少妇| 欧美精品videofree1080p| 国产成人精品在线| 精品色蜜蜜精品视频在线观看| 欧美国产第二页| 亚洲国产精品美女| 另类少妇人与禽zozz0性伦| 91精品久久久久久久| 91精品视频在线免费观看| 欧美日韩中文在线观看| 欧美日韩性视频| 亚洲色图狂野欧美| 最近2019好看的中文字幕免费| 国产欧美日韩专区发布| 亚洲第一精品夜夜躁人人躁| 久久精品视频一| 亚洲综合在线做性| 日韩久久午夜影院| 亚洲伊人成综合成人网| 日韩亚洲综合在线| 国产精品一区av| www国产精品视频| 最近2019年中文视频免费在线观看| 久久成人一区二区| 久久久精品在线观看| 国产精品免费福利| 亚洲第一福利视频| 欧美成人精品h版在线观看| 日韩中文字幕免费看| 成人www视频在线观看| 久久久久久久成人| 国产成人拍精品视频午夜网站| 91丝袜美腿美女视频网站| 国产精品一区二区三区久久久| 日韩一区二区三区在线播放| 不卡av日日日| 亚洲精品国精品久久99热一| 欧美孕妇孕交黑巨大网站| 成人久久一区二区三区| 最近2019中文字幕第三页视频| 日韩中文字幕国产精品| 久久综合网hezyo| 粗暴蹂躏中文一区二区三区| 性欧美xxxx视频在线观看| 日韩精品视频中文在线观看| 久久色在线播放| 中文在线资源观看视频网站免费不卡| 日韩中文字幕免费| 精品福利免费观看| 色av中文字幕一区| 久久在线观看视频| 亚洲美女中文字幕| 成人妇女淫片aaaa视频| 国产精品久久久久久久久久久新郎| 91社区国产高清| 国产色综合天天综合网| 日韩视频免费看| 欧美午夜电影在线| 日韩一区二区三区在线播放| 亚洲免费中文字幕| 色偷偷av亚洲男人的天堂| 日韩精品在线观看一区二区| 亚洲欧洲午夜一线一品| 一区二区欧美久久| 亚洲视频在线观看网站| 欧美久久精品一级黑人c片| 国产成人精品视频在线观看| 欧美黄色片在线观看| 欧美在线性视频| 久久久久久亚洲精品| 超碰精品一区二区三区乱码| 欧美猛交免费看| 久久精品91久久香蕉加勒比| 欧美性猛交xxxx黑人猛交| 国产精品青草久久久久福利99| 久久久噜噜噜久久中文字免| 国产成人精品久久二区二区91| 91视频免费在线| 亚洲欧美日韩精品久久亚洲区| 在线日韩中文字幕| 亚洲综合在线做性| 欧美疯狂性受xxxxx另类| 在线看福利67194| 日韩精品中文字幕在线观看| 久久精品国产成人| 精品成人av一区| 66m—66摸成人免费视频| 国产精品自拍小视频| 亚洲电影免费观看高清完整版| 日av在线播放中文不卡| 日韩欧美国产一区二区| 亚洲精品乱码久久久久久金桔影视| 北条麻妃一区二区三区中文字幕| 色99之美女主播在线视频| 国产精品手机播放| 亚洲欧洲美洲在线综合| 3344国产精品免费看| 国外成人在线播放| 成人欧美一区二区三区黑人| 久久久久五月天| 国产97在线亚洲| 亚洲精品自拍偷拍| 精品人伦一区二区三区蜜桃免费| 国产视频999| 亚洲欧美在线播放| 亚洲区bt下载| 91欧美精品午夜性色福利在线| 91高清视频在线免费观看| 日韩av电影手机在线观看| 日韩综合视频在线观看| 一区二区欧美激情| 亚洲成人网在线| 国产精品情侣自拍| 色综合久综合久久综合久鬼88| 成人网在线视频| 91免费视频国产| 国产亚洲欧美日韩精品| 日韩美女福利视频| 国产91对白在线播放| 国产欧美精品久久久| 91超碰中文字幕久久精品| 成人精品视频99在线观看免费| 欧美性videos高清精品| 美女精品视频一区| 国产精品大陆在线观看| 亚洲乱码av中文一区二区| 亚洲欧美999|