Validator驗證Ajax提交表單的方法


當我們在一些稍微復雜的業務時,可能會遇到需要多個表單form在同一個頁面的情況,但是提交一個表單以后不想頁面刷新或者跳轉,那么我們考慮到的就是Ajax提交表單,那么如何讓Jquery的validator插件也可以對異步提交的表單進行驗證呢?我們繼續往下看。

在這里,我就用網絡上的一個例子來說明好了。

下面是一個比較常見的jquery .ajax提交表單的寫法

Js代碼   收藏代碼
  1. $("#submitButton").click(function(){  
  2. //序列化表單  
  3.    var param = $("#leaveSave").serialize();  
  4.    $.ajax({  
  5.       url : "leaveSave.action",  
  6.       type : "post",  
  7.       dataType : "json",  
  8.       data: param,  
  9.       success : function(result) {  
  10. if(result=='success') {  
  11. location.href='allRequisitionList.action';  
  12. else if(result.startWith("error_")){  
  13. $("#errorMessage").html(result.substring(6));  
  14. else {  
  15. //返回的結果轉換成JSON數據  
  16. var jsonObj = eval('('+result+')');  
  17. startTime = $("#startdate").val();  
  18. endTime = $("#enddate").val();  
  19. hour = jsonObj.hour;  
  20. reason = jsonObj.reason;  
  21.   
  22. replaceDom(startTime,endTime,hour,reason);  
  23. }  
  24. }  
  25. });  
  26. });   



如果想用ajax提交表單,還想用jquery的validate進行驗證,那么可以這樣解決:表單還是正常編寫的表單內容,type還是submit類型,只不過在validate驗證通過后的方法中使用ajax提交表單

Js代碼   收藏代碼
    1. $("#saveWorkExtra").validate({  
    2. onsubmit:true,// 是否在提交是驗證  
    3. onfocusout:false,// 是否在獲取焦點時驗證  
    4. onkeyup :false,// 是否在敲擊鍵盤時驗證  
    5.   
    6. rules: {  
    7. ....  
    8. },  
    9. messages:{  
    10. ....  
    11. },  
    12. submitHandler: function(form) {  //通過之后回調  
    13.      var param = $("#saveToWorkExtra").serialize();  
    14.      $.ajax({  
    15. url : "workExtraChange.action",  
    16. type : "post",  
    17. dataType : "json",  
    18. data: param,  
    19. success : function(result) {  
    20. if(result=='success') {  
    21.           location.href='allRequisitionList.action';  
    22. else {  
    23.           var jsonObj = eval('('+result+')');  
    24. }  
    25. }  
    26.      });  
    27.          },  
    28.          invalidHandler: function(form, validator) {  //不通過回調  
    29.        return false;  
    30.           }  
    31. });  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM