這次帶給大家jQuery怎麼驗證Ajax提交表單傳參,jQuery驗證Ajax提交表單傳參的注意事項有哪些,下面就是實戰案例,一起來看一下。
serialize() 方法透過序列化表單值,建立 URL 編碼文字字串。取代了一個一個傳參的方式
以往寫的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) { } });
當我們在一些稍微複雜的業務時,可能會遇到需要多個表單form在同一個頁面的情況,但是提交一個表單以後不想頁面刷新或跳轉,那麼我們考慮到的就是Ajax提交表單,那麼如何讓jQuery的validator外掛程式也可以對非同步提交的表單進行驗證呢?我們繼續往下看。
在這裡,我就用網路上的一個例子來說明好了。
下面是一個比較常見的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 { //返回的结果转换成JSON数据 var jsonObj = eval('('+result+')'); startTime = $("#startdate").val(); endTime = $("#enddate").val(); hour = jsonObj.hour; reason = jsonObj.reason; replaceDom(startTime,endTime,hour,reason); } } }); });
如果想用ajax提交表單,還想用jquery的validate進行驗證,那麼可以這樣解決:表單還是正常編寫的表單內容,type還是submit類型,只不過在validate驗證通過後的方法中使用ajax提交表單
$("#saveWorkExtra").validate({ onsubmit:true,// 是否在提交是验证 onfocusout:false,// 是否在获取焦点时验证 onkeyup :false,// 是否在敲击键盘时验证 rules: { .... }, messages:{ .... }, submitHandler: function(form) { //通过之后回调 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) { //不通过回调 return false; } });
#相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
推薦閱讀:
#以上是jQuery怎麼驗證Ajax提交表單傳參的詳細內容。更多資訊請關注PHP中文網其他相關文章!