有时间整理。。。

 

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

下面开始贴出方法。

 

[javascript]  view plain copy
 
  1. //跨域(可跨所有域名)  
  2. $.getJSON("http://user.hnce.com.cn/getregion.aspx?id=0&jsoncallback=?",function(json){  
  3.    
  4.  //要求远程请求页面的数据格式为: ?(json_data)    
  5.  //例如:  
  6.  //?([{"_name":"湖南省","_regionId":134},{"_name":"北京市","_regionId":143}])  
  7.  alert(json[0]._name);  
  8.   
  9.  });    

 

 

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

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

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

 

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

 

[javascript]  view plain copy
 
  1. <mce:script src=cript"></mce:script>  
  2. <mce:script type="text/javascript"><!--  
  3. //跨域(可跨所有域名)  
  4.     $.getJSON("http://e.hnce.com.cn/tools/ajax.aspx?jsoncallback=?", { id: 0, action: 'jobcategoryjson' }, function(json) {  
  5.   
  6.         alert(json[0].pid);  
  7.         alert(json[0].items[0]._name);  
  8.   
  9.     });   
  10. // --></mce:script>