[转载]JQuery 的跨域方法 可跨新浪、腾讯、经网等任意网站

baacloud免费翻墙vpn注册使用

[转载]JQuery 的跨域方法 可跨新浪、腾讯、经网等任意网站 – Taven – 博客园.

因发现有不少博友发园内短信问及JS的跨域问题,我想很多程序员的脑海里面还认为JS是不能跨域的,其实这是一个错误的观点;有很多人在网上找其解 决方法,教其用IFRAME去解决的文章很多,真有那么复杂吗?其实很简单的,如果你用JQuery,一个GETJSON方法就搞定了,而且是一行代码搞 定。

下面开始贴出方法。

//跨域(可跨所有域 名)
$.getJSON(http://user.hnce.com.cn/getregion.aspx?id=0&jsoncallback=?,function(json){

//要求远程请求页面的数据格式为: ?(json_data)
//例如:
//?([{“_name”:”湖南省”,”_regionId”:134},{“_name”:”北京 市”,”_regionId”:143}])
alert(json[0]._name);

});

注意,getregion.aspx中,在输出JSON数据时,一定要用Request.QueryString[“jsoncallback”],将获 取的内容放到返回JSON数据的前面,假设实际获取的值为42342348,那么返回的值就是 42342348([{“_name”:”湖南省”,”_regionId”:134},{“_name”:”北京 市”,”_regionId”:143}])

因为getJSON跨域的原理是把?随机变一个方法名,然后返回执行的,实现跨域响应的目的。

具体getJSON的使用说明,请参考JQuery手册。

下面一个是跨域执行的真实例子:

代码

<script src=http://common.cnblogs.com/script/JQuery.js type=text/JavaScript></script>
<script type=text/JavaScript>
//跨域(可跨所有域名)
$.getJSON(http://e.hnce.com.cn/tools/ajax.aspx?jsoncallback=?, { id: 0, action: jobcategoryjson }, function(json) {

alert(json[0].pid);
alert(json[
0].items[0]._name);

});
</script>

作者:Taven.李锡远
出处:http://taven.cnblogs.com
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

赞(0) 打赏
分享到: 更多 (0)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏