DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> jQuery入門知識 >> JQuery特效代碼 >> jquery $.getJSON()跨域請求
jquery $.getJSON()跨域請求
編輯:JQuery特效代碼     
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);
})
});

服務器返回字符串:
jQuery1706543070425920333_1324445763158({"Name":"loogn","Age":23})
返回的字符串就是一個調用一個叫“jQuery1706543070425920333_1324445763158” 的函數,參數是{"Name":"loogn","Age":23}。
其實這個很長的函數名是請求路徑中callback=?的作用,我想應該是這樣的:$.getJSON方法生成一個對回調方法的引用的名字,換掉?。上面請求會變成
http://localhost:2589/a.ashx?callback=jQuery1706543070425920333_1324445763158&_=1324445763194,所服務器回返json時要處理一下,如:
. 代碼如下:
string cb = context.Request["callback"];
context.Response.Write(cb + "(" + json + ")");

參數名callback也可換成jsoncallback,我想是怕沖突吧,jsoncallback應該優先檢測,沒有再檢測callback(沒測試!!)
?也可是具體的函數名,這樣回調函數就不能是匿名的了,用?生成只是jQuery為我們的一般操作提供的一個便利。
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved