附上代碼如下:
JScript code:
複製代碼 代碼如下:$.ajax({
type: "post",
url: "jsp/loginManager.jsp",
data: "name=" + $('#rname').attr('value') + "&pwd=" + $('#pwd').attr('value'),
dataType: "text",
success: function(data) {
alert(data);
}
});
點擊登陸,成功串連資料庫並且查詢到了值(在loginManager.jsp頁面有用System.out.print()列印過查詢到的值)。但success裡的東西不執行。用過斷點,當執行完dataType後,success直接跳出,裡面的alert()不執行,這是為什麼呢?
改了下代碼,如下:
JScript code: 複製代碼 代碼如下:$.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);
}
});
但是還是一樣,沒反應,只是把登陸頁面重新整理了!!!
針對上面只是把登入頁面重新整理了的問題,是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)數字,布爾類型不需要 使用雙引號 括起