使用JSONP来进行mashup

发布于 2022-10-15 08:42:38 字数 2141 浏览 25 评论 0

转:前端开发(xing)

使用JSONP来进行mashup
什么是JSONP?

view sourceprint?
JSONP即JSON with Padding。由于同源策略的限制,XmlHttpRequest只允许请求当前源(域名、协议、端口)的资源。如果要进行跨域请求,我们可以通过使用 html的script标记来进行跨域请求,并在响应中返回要执行的script代码,其中可以直接使用JSON传递javascript对象。这种跨域的通讯方式称为JSONP。

使用jQuery

view sourceprint?

  1. $.ajax({  
  2.     url:'http://api.flickr.com/services/feeds/photos_public.gne?format=json&jsoncallback=?',  
  3.     dataType:'jsonp',  
  4.     success:function(data){  
  5.         console.log(data);  
  6.     }  
  7. });

复制代码注意其中的jsoncallback针对不同的服务提供商是变化的。比如推特就是callback~~

使用Dojo

view sourceprint?

  1. /**  
  2. * @author xing  
  3. */
  4. dojo.provide("libs.test");  
  5. dojo.require("dojo.io.script");  
  6. dojo.io.script.get({  
  7.     url:'http://api.flickr.com/services/feeds/photos_public.gne',  
  8.     content:{  
  9.         format:'json',  
  10.         tags:'cyndi wang'
  11.     },  
  12.     callbackParamName:'jsoncallback',  
  13.     load:function(data){  
  14.         console.log(data);  
  15.     }  
  16. });

复制代码使用dojo最方便的就是按需加载吧~callbackParamName替换成服务提供商的约定的函数名称就可以了。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文