您的位置:首页 > Web前端 > JavaScript

$.getJSON()跨域请求

2015-09-20 21:49 761 查看
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时要处理一下,如:
*****服务器记得加上callback

string cb = context.Request["callback"];

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

参数名callback也可换成jsoncallback,我想是怕冲突吧,jsoncallback应该优先检测,没有再检测callback(没测试!!)

?也可是具体的函数名,这样回调函数就不能是匿名的了,用?生成只是jQuery为我们的一般操作提供的一个便利。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: