jsonp获取服务器数据的方式

前端之家收集整理的这篇文章主要介绍了jsonp获取服务器数据的方式前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
@H_404_1@
  • jsonp获取服务器的数据,有两种
  • 一,跨域
  • 二,不跨域
  • 如果跨域
  • js的写法有两种
  • 1,
  • <scripttype="text/javascript">
  • $(function(){
  • $.getJSON('http://localhost:8090/search?jsoncallback=?',
  • function(json){
  • alert(json);
  • varhtml="";
  • for(varkeyinjson.data){
  • html=html+"<imgsrc='http://localhost:8090/img/99999/o/"+json.data[key].filename+"'><br>";
  • html=html+"名称:"+json.data[key].filename+"<br>";
  • html=html+"category:"+json.data[key].category+"<br>";
  • html=html+"height:"+json.data[key].height+"<br>";
  • html=html+"width:"+json.data[key].width+"<br>";
  • html=html+"length:"+json.data[key].length+"<br>";
  • html=html+"<hr>";
  • }
  • $('#imageList').html(html);
  • }
  • );
  • });
  • </script>
  • get的ur后面有jsoncallback=?
  • 这时候,要在服务器端增加如下代码
  • hr.getParameter("jsoncallback")+"({jsonp数据的格式})"
  • 例子
  • jQuery1510062266528242707175_1324369820794({"data":[{"category":"all","height":"194","_id":"4ebce7b5523e7e91029f910a","keyword":"","width":"259","chunkSize":"262144","length":"9082","md5":"534a94756fc98a6db0483ee702297a82","filename":"img001_images_029.jpeg","contentType":"null","uploadDate":"FriNov1118:15:33JST2011","aliases":"null"},{"category":"all","_id":"4ebce7b5523e7e91029f9108","length":"10987","md5":"7b85b894132f78b2b90cd3fef27317a6","filename":"img001_images_028.jpeg","aliases":"null"}]});
  • 注意,是如下格式jQuery1510062266528242707175_1324369820794({xxxx}),要加个()的哦。
  • 2,get的ur后面有jsoncallback=?的写法可以改为get的ur后面有jsoncallback=getdata
  • 同时function(json)前要加上getdata=
  • 具体如下
  • <scripttype="text/javascript">
  • $(function(){
  • $.getJSON('http://localhost:8090/search?jsoncallback=getdata',
  • getdata=function(json){
  • alert(json);
  • varhtml="";
  • for(varkeyinjson.data){
  • html=html+"<imgsrc='http://localhost:8090/img/99999/o/"+json.data[key].filename+"'><br>";
  • html=html+"名称:"+json.data[key].filename+"<br>";
  • html=html+"category:"+json.data[key].category+"<br>";
  • html=html+"height:"+json.data[key].height+"<br>";
  • html=html+"width:"+json.data[key].width+"<br>";
  • html=html+"length:"+json.data[key].length+"<br>";
  • html=html+"<hr>";
  • $('#imageList').html(html);
  • );
  • });
  • </script>
  • 这个时候,服务器端就不需要加上hr.getParameter("jsoncallback")了,直接返回json格式就行了。
  • 具体参见
  • http://www.cnblogs.com/5201314/archive/2009/06/23/1509552.html
  • http://51mst.iteye.com/blog/1170798
  • 二,如果是不跨域的,
  • 不需要加上jsoncallback,直接如下就行了,同时服务器返回的格式,就是纯jsonp的格式。
  • $.getJSON('http://localhost:8090/search',85); line-height:18px"> alert(1);
  • 服务器返回代码
  • {"data":[{"category":"all","aliases":"null"}]}
  • 猜你在找的Json相关文章