作家
登录

JQuery Ajax 跨域访问的解决方案

作者: 来源:www.28hudong.com 2013-03-30 01:47:44 阅读 我要评论

具体情况有: 一、本域和子域的相互访问: http://www.aa.com/和book.aa.com 二、本域和其他域的相互访问: http://www.aa.com/和http://www.bb.com/ 用 iframe 三、本域和其他域的相互访问: http://www.aa.com/和http://www.bb.com/ 用 XMLHttpRequest访问代理 四、本域和其他域的相互访问: http://www.aa.com/和http://www.bb.com/ 用 JS创建动态脚本 今天主要讨论第4中解决方案,这个和上个的区别就是请求是使用<script>标签来请求的,这个要求也是两个域都是由你来开发才行。原理就是JS文件注入,在本域内的a内生成一个JS标签,它的SRC指向请求的另外一个域的某个页面b,b返回数据即可,可以直接返回JS的代码。因为script的src属性是可以跨域的。 这里我们需要用到JQuery.getScript(url, callback)方法,url是脚本文件的URL路劲,callback函数在脚本资源已被加载和求值后调用的回调函数。 首先在bb.com创建一个js文件,test.js 复制代码 代码如下: var ojb = {msg:'js跨域请求成功'}; 然后在aa.com的页面上使用$.getScript加载test.js脚本 复制代码 代码如下: $(function() { $.getScript('http://www.bb.com/test.js', function() { if (ojb) { alert(obj.msg); } }); }); 使用$.getScript函数的最大好处就是可以保证,脚本加载完毕后调用回调函数。 个人感觉这种方法比使用代理和iframe要简单一些。

  推荐阅读

  javascript之嵌套函数使用方法

在javascript中允许使用嵌套函数: 嵌套函数 [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行] 记住这名话: 嵌套实际是要实现一种循环,是循环就有双个把柄让我们抓:一个是终止条件,一>>>详细阅读


本文标题:JQuery Ajax 跨域访问的解决方案

地址:http://www.17bianji.com/kaifa2/JS/26898.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)