這篇文章將為大家詳細(xì)講解有關(guān)jQuery中Validator如何驗(yàn)證Ajax提交表單和Ajax傳參,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
serialize() 方法通過(guò)序列化表單值,創(chuàng)建 URL 編碼文本字符串。代替了一個(gè)一個(gè)傳參的方式
以往寫的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è)比較常見的jquery .ajax提交表單的寫法
$("#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)證,那么可以這樣解決:表單還是正常編寫的表單內(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; } });
關(guān)于“jQuery中Validator如何驗(yàn)證Ajax提交表單和Ajax傳參”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。
網(wǎng)頁(yè)題目:jQuery中Validator如何驗(yàn)證Ajax提交表單和Ajax傳參-創(chuàng)新互聯(lián)
網(wǎng)站鏈接:http://aaarwkj.com/article30/jdipo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號(hào)、網(wǎng)站收錄、軟件開發(fā)、做網(wǎng)站、網(wǎng)站建設(shè)、網(wǎng)站內(nèi)鏈
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容