2014-06-14 166 views
0

當我提交表單時,Jquery驗證器不能再次工作。驗證程序未第二次附加到提交事件。Jquery驗證器第二次不工作

我沒有提交處理程序,但valid()函數也沒有被調用。

<script> 
    $(document).ready(function() { 
     $("#login_form").submit(function() { 
      $("#login_form").validate({ 
       rules: { 
        username: { 
         required: true 
        }, 
        password: { 
         required: true, 
         minlength: 6 
        } 
       }, 

       messages: { 
        username: { 
         required: "Enter your username" 
               }, 
        password: { 
         required: "Enter your password", 
         minlength: "Password must be minimum 6 characters" 
        }, 
       }, 



       errorPlacement: function(error, element) { 
        error.hide(); 
        $('.messagebox').hide(); 
        error.appendTo($('#alert-message')); 
        $('.messagebox').slideDown('slow'); 



       }, 
       highlight: function(element, errorClass, validClass) { 
        $(element).parents('.form-group').addClass('has-error'); 
       }, 
       unhighlight: function(element, errorClass, validClass) { 
        $(element).parents('.form-group').removeClass('has-error'); 
        $(element).parents('.form-group').addClass('has-success'); 
       } 
      }); 

      if ($("#login_form").valid()) { 
       var data1 = $('#login_form').serialize(); 
       $.ajax({ 
        type: "POST", 
        url: "login.php", 
        data: data1, 
        dataType: 'json', 
        success: function(msg) { 

         if (msg.result == 1) { 
         $('.messagebox').addClass("success-message"); 
         $('.message').slideDown('slow'); 
         $('#alert-message').text("Logged in.. Redirecting"); 

          $('#login_form').fadeOut(5000); 
          window.location = "members.php" 
         } else {  
         console.log(msg.result); 
         $('.messagebox').hide(); 
         $('.messagebox').addClass("error-message"); 
         $('#alert-message').html(msg.result); 
         $('.messagebox').slideDown('slow'); 
         } 
        } 
       }); 
      } 
      return false; 
     }); 

    }); 
</script> 
+0

您的成功,函數看起來怪異 –

+0

抱歉。現在更新它。 – Jeyaganesh

+0

你有兩個問題:1)'.validate()'方法不屬於'submit'處理函數的內部。 2)你的'ajax'屬於插件的'submitHandler'回調函數選項的內部。 – Sparky

回答

0

的問題是在這裏:

$("#login_form").submit(function() { 
     $("#login_form").validate({... 

你重新綁定驗證每個表單提交,您的驗證綁定只應在的document.ready事件一次設置,你應該始終設置/綁定jquery只在文檔就緒事件和頁面加載中進行驗證,而不是在Ajax回發中再次進行驗證。你在射擊驗證正確的檢查中多次提交表單的事件,像這樣雖:

$("#login_form").submit(function() { 
    if ($("#login_form").valid()) {... 

這裏是固定的代碼:

<script> 
$(document).ready(function() { 

     $("#login_form").validate({ 
      rules: { 
       username: { 
        required: true 
       }, 
       password: { 
        required: true, 
        minlength: 6 
       } 
      }, 

      messages: { 
       username: { 
        required: "Enter your username" 
              }, 
       password: { 
        required: "Enter your password", 
        minlength: "Password must be minimum 6 characters" 
       }, 
      }, 



      errorPlacement: function(error, element) { 
       error.hide(); 
       $('.messagebox').hide(); 
       error.appendTo($('#alert-message')); 
       $('.messagebox').slideDown('slow'); 



      }, 
      highlight: function(element, errorClass, validClass) { 
       $(element).parents('.form-group').addClass('has-error'); 
      }, 
      unhighlight: function(element, errorClass, validClass) { 
       $(element).parents('.form-group').removeClass('has-error'); 
       $(element).parents('.form-group').addClass('has-success'); 
      } 
     });//end validate bindings/settings 


    $("#login_form").submit(function() { 
          //fire validation checks 
     if ($("#login_form").valid()) { 
      var data1 = $('#login_form').serialize(); 
      $.ajax({ 
       type: "POST", 
       url: "login.php", 
       data: data1, 
       dataType: 'json', 
       success: function(msg) { 

        if (msg.result == 1) { 
        $('.messagebox').addClass("success-message"); 
        $('.message').slideDown('slow'); 
        $('#alert-message').text("Logged in.. Redirecting"); 

         $('#login_form').fadeOut(5000); 
         window.location = "members.php" 
        } else {  
        console.log(msg.result); 
        $('.messagebox').hide(); 
        $('.messagebox').addClass("error-message"); 
        $('#alert-message').html(msg.result); 
        $('.messagebox').slideDown('slow'); 
        } 
       } 
      }); 
     } 
     return false; 
    }); 

});