首页 > web前端 > js教程 > JQuery Ajax 跨域访问的解决方案_jquery

JQuery Ajax 跨域访问的解决方案_jquery

WBOY
发布: 2016-05-16 18:32:39
原创
926 人浏览过

具体情况有:
一、本域和子域的相互访问: 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属性是可以跨域的。 <BR>这里我们需要用到JQuery.getScript(url, callback)方法,url是脚本文件的URL路劲,callback函数在脚本资源已被加载和求值后调用的回调函数。 <BR>首先在bb.com创建一个js文件,test.js <BR><div class="codetitle"><span><a style="CURSOR: pointer" data="69218" class="copybut" id="copybut69218" onclick="doCopy('code69218')"><U>复制代码 代码如下:<div class="codebody" id="code69218"> <BR>var ojb = {msg:'js跨域请求成功'}; <BR> <BR>然后在aa.com的页面上使用$.getScript加载test.js脚本 <BR><div class="codetitle"><span><a style="CURSOR: pointer" data="60932" class="copybut" id="copybut60932" onclick="doCopy('code60932')"><U>复制代码 代码如下:<div class="codebody" id="code60932"> <BR>$(function() { <BR>$.getScript('http://www.bb.com/test.js', function() { <BR>if (ojb) { <BR>alert(obj.msg); <BR>} <BR>}); <BR>}); <BR> <BR>使用$.getScript函数的最大好处就是可以保证,脚本加载完毕后调用回调函数。 <BR>个人感觉这种方法比使用代理和iframe要简单一些。 </script>

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板