首頁 > web前端 > js教程 > 主體

jquery $.getJSON()跨域請求

巴扎黑
發布: 2017-07-03 09:44:33
原創
1016 人瀏覽過

以前總是沒搞明白是怎麼回事,現在是迫不得已,就仔細看了看說明文檔,終於測試成功了,記下

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,所處理伺服器時要處理一下伺服器

string

cb = context.Request["callback"];

context.Response.Write(cb + "(" + json + ")");


參數名稱callback也可換成jsoncallback,我想是怕衝突吧,jsoncallback應該優先檢測,沒有再檢測callback(沒測試!!)
?也可是具體的函數名,這樣

回呼函數

就不能是匿名的了,用?生成只是jQuery為我們的一般操作提供的一個便利。

以上是jquery $.getJSON()跨域請求的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板