JSONP

来自站长百科
跳转至: 导航、​ 搜索

JSONP包括IE6在内的大多浏览器支持的标准跨域数据访问方式。核心思想是利用JS标签里面的跨域特性进行跨域数据访问,在JS标签里面存在的是一个跨域的URL,实际执行的时候通过这个URL获得一段字符串,这段返回的字符串必须是一个合法的JS调用,通过EVAL这个字符串来完成对获得的数据的处理。

JSONP实现[ ]

  • 大多JS框架都支持一个包装后的JSONP实现。
例如EXTJS
在URL里面指定跨域的目标地址,在PARAMS里面指定传递过去的参数,这些都和AJAX的实现一样。
  • 不一样的地方如下:
实际传递的时候,EXT框架会自动添加一个叫做callback的参数,这个参数每次调用都不一样,不用管他。
在后台处理的时候,获得这个callback的参数,直接把它当做一个js函数调用的名字,加上括号,和你自己希望提供的字符串,组合起来就是一个合法的js方法调用,在ext框架里面,这个方法调用的是success方法 .

服务器端实现对JSON支持[ ]

  • 这仅仅需要把服务的JSON数据转换成想要的script tags的形式就可以了,格式可以自已定义,毕竟这是个非官方的协议。
  • 可参考:Implement JSONP in your Asp.net Application
  • 注:Callback仅仅是JSONP的简单实现,可以根据具体需要实现更复杂的功能,比如可以在客户端动态集成更多的变量数据来完成分页功能。

JSONP在JQuery中的体现[ ]

1. $.getJSON

  <script>
  $(document).ready(function(){
  $.getJSON("http://api.flickr.com/services/feeds/photos_public.gne?
       tags=cat&tagmode=any&format=json&jsoncallback=?",
  function(data){
  $.each(data.items, function(i,item){
  $("<img/>").attr("src", item.media.m).appendTo("#images");
  if ( i == 3 ) return false;
  });
  });
  });
  </script>
  jsoncallback=?,其中?会自动替换为function(data)函数。

2. $.ajax

  $.ajax({
  dataType: 'jsonp',
  data: 'id=10',
  jsonp: 'jsonp_callback',
  url: 'http://www.yiwuku.com/getdata',
  success: function () {
  // do stuff
  },
  });

相关条目[ ]

参考来源[ ]