教程集 www.jiaochengji.com
教程集 >  jQuery  >  jquery 教程  >  正文 基于Jquery的跨域传输数据(JSONP)

基于Jquery的跨域传输数据(JSONP)

发布时间:2013-07-12   编辑:jiaochengji.com
基于Jquery的跨域传输数据(JSONP) ,需要的朋友可以参考下。
基于jquery的跨域传输数据(JSONP) ,需要的朋友可以参考下。 后端:
复制代码 代码如下:

<?php
$json_str = json_encode(array("ddd"=>"11111111"));
echo $_GET['ja'].'('.$json_str.')';
?>

前端:
复制代码 代码如下:

$.getJSON('http://www.liushan.cn/test.php?ja=?',function (json){
alert(json);
});

纯JS实现(JSONP):
复制代码 代码如下:

//server return aa({'ddd':'ddd'}) callback function name: $_GET['callback']
//author:lonely
(function(w){
function getjson(){}
getjson.prototype.set=function(url,callback,callbackname){
this.callfn=callbackname||'urlcallback';
this.url=url+"?callback="+this.callfn;
try{
eval(this.callfn+"=function(data){\n"+
"callback(data);\n"+
'delete '+this.callfn+';}');
}catch(e){return;}
this.request();
delete this.url;
}
getjson.prototype.request=function(){
var script=document.createElement("script");
script.src=this.url;
var load=false;
script.onload = script.onreadystatechange = function() {
if(this.readyState === "loaded" || this.readyState === "complete"){
load=true;
script.onload = script.onreadystatechange=null;
}
};
var head=document.getElementsByTagName("head")[0];
head.insertBefore(script,head.firstChild);
}
w.getjson=getjson;
})(window)
//使用DOME
new getjson().set("http://www.test.cn/test.php",function(data){
alert(data.ddd);
});

另一个:getScript
复制代码 代码如下:

jQuery.getScript("http://dev.jquery.com/view/trunk/plugins/color/jquery.color.js", function(){
$("#go").click(function(){
$(".block").animate( { backgroundColor: 'pink' }, 1000)
.animate( { backgroundColor: 'blue' }, 1000);
});
});//CHM帮助文件示例

您可能感兴趣的文章:
基于Jquery的跨域传输数据(JSONP)
jQuery 跨域访问问题解决方法
jQuery JSONP跨域需要怎样实现
jquery下利用jsonp跨域访问实现方法
跨域请求之jQuery的ajax jsonp的使用解惑
JQuery的Ajax跨域请求原理概述及实例
jQuery-JSONP
php中json的跨域实例分析
Jsonp 跨域的原理以及Jquery的解决方案
django如何解决跨域问题

[关闭]
~ ~