同源是指两个站点同协议,同端口,同域名。
同源策略规定:不同域的客户端脚本在没有明确授权的情况下,不能读写对方资源。
但是,在数据传输过程中,经常会发生跨域的数据交换,那么如何解决这个问题呢。。就利用到了一些支持跨域传输的标签(比如<script>、<img>等)
<script type = "text/javascript" src = "http://www.pp.com/alert.js"></script>
既然他可以跨域传输,那么如果引用的"www.pp.com/alert.js"中有
test();
kuayu();
那么,它执行的顺序就是,先执行test(),在执行kuayu();
这是,如果你自己的页面有个函数
function kuayu(){
alert("lalala");
}
那么因为是引用进来的。然后他走test(),然后执行kuayu(),所以就弹出lalala!了。
如果这个方法有形参的话,那么,这个形参就可以了当做载体,来传递我们想传递的值了!
function kuayu(json){
alert("我获取到了 跨域值"+ json );
}
-----------------------
pp.com/alert.js .....
.....
....
kuayu("我是数据,我想跨域,在那边看到我了吗?");
-----------------------------------------------------------
最终输出 我获取到了跨域值, 我是数据,我想跨域,在那边看到我了吗?
ok,以上就是其的基本思想
那么,什么jsonp呢?jsonp就是一种为了解决跨域的数据交换而衍生出来的一种协议。jsonp只可实现get的传输方式。
(jsonp和json就像周杰和周杰伦一样,没有半毛钱关系!!)
原理说完了,接下来上代码!!
function localHandler(data) {
console.log("fengshu")
console.log(data);
}
var ajaxParam = {
async: false,
url: ajaxUrl,
type: "GET",
dataType: 'jsonp',//非正式跨域传输协议
jsonp: 'localHandler',
success: function (json) {
//回调数据在localHandler处理
}
};
$.ajax(ajaxParam);