jQuery Validator驗(yàn)證Ajax提交表單的方法和Ajax傳參的方法
serialize() 方法通過(guò)序列化表單值,創(chuàng)建 URL 編碼文本字符串。代替了一個(gè)一個(gè)傳參的方式
以往寫(xiě)的ajax傳參方式
$.ajax({ url : "${ctx}/SJStandardDamPartition/insertOrUpdateDamPartition", type : "post", dataType : "json", data: {beginsectionid:function(){ return $('#number option:selected').val(); }, beginelevation:function(){ return $('#onset').val(); }, endelevation:function(){ return $('#end').val(); } }, success : function(result) { } });
用serialize()的傳參方式
var param = $("#standForm").serialize(); $.ajax({ url : "${ctx}/SJStandardStandardInfo/insertOrUpdateStandardInfo", type : "post", dataType : "json", data: param, success : function(result) { } });
當(dāng)我們?cè)谝恍┥晕?fù)雜的業(yè)務(wù)時(shí),可能會(huì)遇到需要多個(gè)表單form在同一個(gè)頁(yè)面的情況,但是提交一個(gè)表單以后不想頁(yè)面刷新或者跳轉(zhuǎn),那么我們考慮到的就是Ajax提交表單,那么如何讓jQuery的validator插件也可以對(duì)異步提交的表單進(jìn)行驗(yàn)證呢?我們繼續(xù)往下看。
在這里,我就用網(wǎng)絡(luò)上的一個(gè)例子來(lái)說(shuō)明好了。
下面是一個(gè)比較常見(jiàn)的jquery .ajax提交表單的寫(xiě)法
$("#submitButton").click(function(){ //序列化表單 var param = $("#leaveSave").serialize(); $.ajax({ url : "leaveSave.action", type : "post", dataType : "json", data: param, success : function(result) { if(result=='success') { location.href='allRequisitionList.action'; } else if(result.startWith("error_")){ $("#errorMessage").html(result.substring(6)); } else { //返回的結(jié)果轉(zhuǎn)換成JSON數(shù)據(jù) var jsonObj = eval('('+result+')'); startTime = $("#startdate").val(); endTime = $("#enddate").val(); hour = jsonObj.hour; reason = jsonObj.reason; replaceDom(startTime,endTime,hour,reason); } } }); });
如果想用ajax提交表單,還想用jquery的validate進(jìn)行驗(yàn)證,那么可以這樣解決:表單還是正常編寫(xiě)的表單內(nèi)容,type還是submit類型,只不過(guò)在validate驗(yàn)證通過(guò)后的方法中使用ajax提交表單
$("#saveWorkExtra").validate({ onsubmit:true,// 是否在提交是驗(yàn)證 onfocusout:false,// 是否在獲取焦點(diǎn)時(shí)驗(yàn)證 onkeyup :false,// 是否在敲擊鍵盤時(shí)驗(yàn)證 rules: { .... }, messages:{ .... }, submitHandler: function(form) { //通過(guò)之后回調(diào) var param = $("#saveToWorkExtra").serialize(); $.ajax({ url : "workExtraChange.action", type : "post", dataType : "json", data: param, success : function(result) { if(result=='success') { location.href='allRequisitionList.action'; } else { var jsonObj = eval('('+result+')'); } } }); }, invalidHandler: function(form, validator) { //不通過(guò)回調(diào) return false; } });
總結(jié)
以上所述是小編給大家介紹的jQuery Validator驗(yàn)證Ajax提交表單的方法和Ajax傳參的方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
ajax回調(diào)函數(shù)中使用$(this)取不到對(duì)象的解決方法
如果在ajax的回調(diào)函數(shù)內(nèi)使用$(this)的話,實(shí)踐證明,是取不到任何對(duì)象的,需要的朋友可以參考下2014-06-06React+ajax+java實(shí)現(xiàn)上傳圖片并預(yù)覽功能
這篇文章主要介紹了React+ajax+java實(shí)現(xiàn)上傳圖片并預(yù)覽功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05關(guān)于前端ajax請(qǐng)求的優(yōu)雅方案(http客戶端為axios)
這篇文章主要給大家介紹了關(guān)于前端ajax請(qǐng)求的優(yōu)雅方案,本文http客戶端為axios,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-12-12ajax異步回調(diào)函數(shù)中給外部變量賦值的問(wèn)題探討
ajax異步回調(diào)函數(shù)中給外部變量賦值的問(wèn)題在本文將為大家詳細(xì)探討下,感興趣的朋友可以參考下2013-09-09用AJAX實(shí)現(xiàn)的無(wú)刷新的分頁(yè)實(shí)現(xiàn)代碼(asp.net)
最近學(xué)習(xí)了AJAX技術(shù)。AJAX,指的是異步的Javascript和xml。它的基本原理就是頁(yè)面用Javascript發(fā)送一個(gè)異步的http請(qǐng)求到服務(wù)器,服務(wù)器返回?cái)?shù)據(jù)后,再用Javascript靜態(tài)的去更改頁(yè)面某個(gè)地方的值,而無(wú)需提交表單。2011-04-04使用jquery 的ajax調(diào)用總是錯(cuò)誤親測(cè)的解決方法
使用jquery 的ajax功能調(diào)用一個(gè)頁(yè)面,卻發(fā)現(xiàn)總是出現(xiàn)錯(cuò)誤,經(jīng)過(guò)這么多測(cè)試終于正常了,尤其是 dataType: 'json',看來(lái)jquery有很嚴(yán)格的驗(yàn)證機(jī)制2013-07-07