2013-03-12 73 views
3

我有一個登錄表單,如果我提交使用傳統的HTML表單後jQuery的AJAX .POST不工作自舉

<form class="form-horizontal" id="loginform"> 
    <div class="control-group"> 
     <label class="control-label" for="user_name"> 
      Username or E-Mail 
     </label> 
     <div class="controls"> 
      <input type="text" id="user_name" name="user_name" autofocus> 
     </div> 
    </div> 
    <div class="control-group"> 
     <label class="control-label" for="password"> 
      Password 
     </label> 
     <div class="controls"> 
      <input type="password" id="password" name="password"> 
     </div> 
    </div> 
    <div class="control-group"> 
     <div class="controls"> 
      <label class="checkbox"> 
       <input type="checkbox">Remember me 
      </label> 
      <br> 
      <button type="submit" class="btn" id="submit_login"> 
       Sign-in 
      </button> 
     </div> 
    </div> 
</form> 

而不是由網頁重定向工作正常,我想有用戶登錄並保持在同一頁面上。我有以下jQuery來做到這一點

$(document).ready(function(){ 
    $("#submit_login").click(function(){ 
     var user_name = $("#user_name").val(); 
     var password = $("#password").val(); 
     $.post("login.php", {user_name: user_name, password: password}); 
    }); 
}); 

但這不是發佈和我的會議不開始。我已經打印了jQuery'user_name'和'password'變量,並且他們從表單中提取了正確的值。 'login.php'文件尋找的變量也是'user_name'和'password'。運行腳本時沒有控制檯錯誤。

這是怎麼造成的脫節?

+6

你不會阻止默認操作,因此正常的形式提交你開始導致中止請求,Ajax請求後會發生。 – 2013-03-12 14:45:43

+0

您是否檢查過控制檯以查看帖子是否實際發送?以及迴應是什麼?那個代碼在收到服務器的響應後什麼也不做,這是有目的的嗎?哦,什麼凱文B說 – cernunnos 2013-03-12 14:45:57

+0

@KevinB是正確的。或者你可以改變你的提交按鈕從類型=「提交」,鍵入=「按鈕」,它將不再嘗試重定向。 – iAmClownShoe 2013-03-12 15:37:44

回答

2

這是一個jQuery val()方法和Bootstrap的btn類的組合,它默認將按鈕設置爲提交按鈕。我切換

var user_name = $("#user_name").val(); 
    var password = $("#password").val(); 

var user_name = document.getElementById("user_name").value; 
    var password = document.getElementById("password").value; 

<button type="submit" class="btn" id="submit_login"> 

<button type="button" class="btn" id="submit_login"> 

和AJAX發揮預期。

的關鍵是改變「提交」按鈕「,而不是僅僅刪除類型分配都在一起。如果沒有指定類型,默認鍵鍵入「提交」

2

您應該在發送您的$.post以避免默認表單提交之前立即阻止默認操作,否則您的$.post將(在大多數情況下)中止。

$(document).ready(function(){ 
    $("#submit_login").click(function(event){ 
     event.preventDefault(); // stop form submit 
     var user_name = $("#user_name").val(); 
     var password = $("#password").val(); 
     $.post("login.php", {user_name: user_name, password: password}); 
    }); 
}); 
+0

嗨凱文,我增加了event.preventDefault(),但後仍然沒有提交。任何其他的想法可能是錯的? – 2013-03-13 15:40:42

+0

你在php方面做過任何調試嗎? – 2013-03-13 15:45:37

+0

是的,這不是PHP相關的,因爲我可以提交表單沒有AJAX – 2013-03-13 15:47:09