JQuery 的跨域方法推荐_可跨任何网站

前端技术 2023/09/01 JavaScript

因发现有不少博友发园内短信问及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手册。

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

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

--><script src=\"http://common.phpstudy.net/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>

以上这篇JQuery 的跨域方法推荐_可跨任何网站就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持phpstudy。

本文地址:https://www.stayed.cn/item/1275

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。