→ lyforever:JSON.stringify(response), 不過你確定你回傳的是json? 06/04 17:42
確定是json
[{"areaname":"臺中市大里區","areacode":"6602800000","zipcode":"412"}]
您的方法我剛剛試過,還是不行,
PS:在IE8是正常的,FF就是不行
※ 編輯: pttnews 來自: 210.63.96.2 (06/04 18:07)
推 s25g5d4:先trim在parse 06/04 18:30
→ lyforever:我其實想問 你dataType為什麼要設text.... 06/04 18:35
→ lyforever:The type of data that you're expecting back from the 06/04 18:35
→ lyforever:server 06/04 18:36
dataType 設為 json 這個方法,很慚愧,我不熟悉,
我一直都是 $.parseJSON(response) , JSON.parse(response)是初次使用
不過這兩種方法都試過。
我覺得問題不是出在
var json = JSON.parse(response.replace(/(\r\n|\n|\r)/gm,""));
因為alert('bb')之前,FF就報出錯誤訊息了
alert('bb');
var json = JSON.parse(response.replace(/(\r\n|\n|\r)/gm,""));
alert('cc');
此外有熱心大大來信,要我測試
alert(
JSON.parse(
'[{"areaname":"臺中市大里區","areacode":"6602800000","zipcode":"412"}]'
)
);
這一行執行正確無誤
※ 編輯: pttnews 來自: 210.63.96.2 (06/04 19:17)
推 No:你的code跟這裡貼的一模一樣嗎? success 少了大括號 } 喔 06/04 19:30
推 s25g5d4:trim不是這樣用的 你可以直接response.trim() 06/04 19:32
→ s25g5d4:不然就console.log(response)看他到底送甚麼東西過來 06/04 19:33
yes sir!
console.log("("+response+")");
出現
(
[{"areaname":"臺中市大里區","areacode":"6602800000","zipcode":"412"}]
)
console.log("("+response.replace(/(\r\n|\n|\r)/gm,"")+")");
出現
([{"areaname":"臺中市大里區","areacode":"6602800000","zipcode":"412"}])
謝謝您
※ 編輯: pttnews 來自: 210.63.96.2 (06/05 09:57)
因為 lyforever大大,提到dataType為什麼要設text.
所以我換成以下兩種方法測試,也是不行,報同樣錯誤。
$.getJSON(
"XXXX/js/address.jsp",
{ area:addCtrl.value , Type:"Query"},
function(response){
alert(response);
}
);
$.ajax({
url: "XXXX/js/address.jsp",
data: { area:addCtrl.value , Type:"Query"},
dataType: 'json',
async: false,
error: function(xhr) {
alert("無法取得代碼檔!!");
},
success: function(json) {
alert(response);
}
});
※ 編輯: pttnews 來自: 210.63.96.2 (06/05 10:47)
→ buganini:把中文去掉呢? 另外多餘的換行應該是在server side就 06/05 16:35
→ buganini:處理好不是傳回來再取代吧… 06/05 16:35