以前總是沒搞明白是怎麼回事,現在是迫不得已,就仔細看了看說明文檔,終於測試成功了,記下
1,同一域名下和其他的請求可以是一樣的
js:
程式碼如下:
var url="http://localhost:2589/a.ashx";
$(function() {
$.getJSON(url,function(data){
alert (data.Name);
})
});
伺服器傳回字串:
{"Name":"loogn","Age":23}
2,不同網域下
js:
程式碼如下:
var url="http://localhost:2589/a.ashx?callback=?";
$(function(){
$.getJSON(url,function(data ){
alert (data.Name);
})
});
#伺服器傳回字串:
jQuery 1706543070425920333_1324445763158({"Name":"loogn","Age":23})
回傳的字串就是一個呼叫一個叫「jQuery1706543070425920333_131"#706543070425920333_124"#70250" loogn","Age":23}。 其實這個很長的函數名稱是請求路徑中callback=?的作用,我想應該是這樣的:$.getJSON方法產生一個回調方法的引用
的名字,換掉? 。上面請求會變成http://localhost:2589/a.ashx?callback=jQuery1706543070425920333_1324445763158&_=1324445763194,所處理伺服器時要處理一下伺服器
cb = context.Request["callback"];
context.Response.Write(cb + "(" + json + ")");
參數名稱callback也可換成jsoncallback,我想是怕衝突吧,jsoncallback應該優先檢測,沒有再檢測callback(沒測試!!)
?也可是具體的函數名,這樣
就不能是匿名的了,用?生成只是jQuery為我們的一般操作提供的一個便利。
以上是jquery $.getJSON()跨域請求的詳細內容。更多資訊請關注PHP中文網其他相關文章!