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 }, });