ajax不執行success回調而是執行了error回調

ajax不執行success回調而是執行了error回調jquery

 

 

最近在看jQuery的API文檔,在使用到jQuery的ajax時,若是指定了dataType爲json,總是不執行success回調,而是執行了error回調函數ajax

附上代碼以下:
JScript code:
數據庫

複製代碼 代碼以下:json


$.ajax({
type: "post",
url: "jsp/loginManager.jsp",
data: "name=" + $('#rname').attr('value') + "&pwd=" + $('#pwd').attr('value'),
dataType: "text",
success: function(data) {
alert(data);
}
});
api


點擊登錄,成功鏈接數據庫而且查詢到了值(在loginManager.jsp頁面有用System.out.print()打印過查詢到的值)。但success裏的東西不執行。用過斷點,當執行完dataType後,success直接跳出,裏面的alert()不執行,這是爲何呢?
改了下代碼,以下:
JScript code:
異步

複製代碼 代碼以下:jsp


$.ajax({
type: "post",
url: "jsp/loginManager.jsp",
async: true,
data: "name=" + $('#rname').attr('value') + "&pwd=" + $('#pwd').attr('value'),
dataType: "text",
success: function(data) {
alert(data);
},
error: function(e) {
alert(e);
}
});
async


可是仍是同樣,沒反應,只是把登錄頁面刷新了!!!
針對上面只是把登陸頁面刷新了的問題,是a連接裏有點小問題,原來我是a連接裏面有href,開始,href=」",因此刷新了頁面,刷新頁面前進入了action,因此也得到了提交數據,可是還沒來得及返回,就刷新了。改爲href=」#」就ok了!正如:
<a href='#' onclick= ‘delMenuContent(cellvalue)>
還有一個緣由是由於我用的是異步提交,沒等驗證成功的時候已經執行了按鈕的提交事件,因此頁面已經刷新,將其改爲同步提交,按鈕的提交事件必須等ajax驗證結束後判斷是否進行提交就能夠解決這個問題了!

最近在看jQuery的API文檔,在使用到jQuery的ajax時,若是指定了dataType爲json,總是不執行success回調,而是執行了error回調函數,極度鬱悶。後面改成1.2.6版本能夠執行。

  而後繼續下載了幾個jquery版本,如1.3.2,1.4.0的,指定dataType爲json都不能執行success回調,只有小於1.3版本的才能執行success回調。

  最後去jquery的網站找到了在線的api文檔看了下,地址:http://api.jquery.com/jQuery.ajax/ ,發現dataType以下的說明
  "json": Evaluates the response as JSON and returns a JavaScript object. In jQuery 1.4 the JSON data is parsed in a strict manner; any malformed JSON is rejected and a parse error is thrown. (See json.org for more information on proper JSON formatting.)

  原來是jquery1.4版本之後對json格式要求很是嚴格了,要知足json.org網站定義的格式才能執行success回調,不然都會出錯,沒法解析返回的json數據。說的是1.4+以上的,那爲何下載的1.3.2指定dataType爲json時也不能執行success回調呢?

  怪不得不執行,原來我返回的是{success:true,id:1} 這種不規則的字符串,不是嚴格的json格式,改爲{"success":true,"id":"1"} 就能夠正常執行success回調了。
  
  JSON格式總結下,詳細的去json.org 查看。
  1)鍵名稱:用雙引號 括起
  2)字符串:用使用雙引號 括起
  3)數字,布爾類型不須要 使用雙引號 括起函數

相關文章
相關標籤/搜索