您现在的位置:主页 > 网站制作 > AJAX教程 >

集中数据格式:JSON和JSONP

来源:建站吧 责任编辑:Jzq8 发表时间:2011-12-22 点击:

JSON

JSON(JavaScript Object Notation)是Douglas Crockford提出的。他是一个轻量级的数据交换格式,基于JavaScript对象字面量。
我们可以将之前的XML图书格式的文件内容转换成下面的JSON格式:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
[
   {
       title: "The Principles of Beautiful Web Design, 2nd Edition",
       url: "http://www.sitepoint.com/books/design2/",
       author: "Jason Beaird",
       publisher: "SitePoint",
       price: {
           currency: "USD",
           amount: 39.95
        }
    },
    {
        title: "jQuery: Novice to Ninja",
        url: "http://www.sitepoint.com/books/jquery1/",
        author: "JEarle Castledine & Craig Sharkie",
        publisher: "SitePoint",
        price: {
            currency: "USD",
            amount: 29.95
        }
    },
    {
        title: "Build Your Own Database Driven Website",
        url: "http://www.sitepoint.com/books/phpmysql4/",
        author: "Kevin Yank",
        publisher: "SitePoint",
        price: {
            currency: "USD",
            amount: 39.95
        }
    }
]
 
这是一个通过对象来表示书的一种方式,并且有title、url、author、publisher、和price等信息。price是一个子对象,并且他包含货币类型和价格。
在JavaScript中很容易处理JSON。你可以使用浏览器原生的JSON.parse方法或者Douglas Crockford的JSON-js库。就算这些都不能用,你也可以使用javaScript的eval方法。不需要再写额外的处理数据的方法:
1
2
3
4
var json = xhr.responseText;
var book = JSON.parse(json);
alert(book[0].title); //first book title
alert(book[1].url); //second book URL
 
使用JSON的优点在于:
  • 比XML轻了很多,没有那么多冗余的东西
  • JSON也是具有很好的可读性的,但是通常返回的都是压缩过后的。不像XML这样的浏览器可以直接显示,浏览器对于JSON的格式化的显示就需要借助一些插件了
  • 在JavaScript中处理JSON很简单
  • 其他语言例如PHP对于JSON的支持也不错
JSON也有一些劣势:
  • JSON在服务端语言的支持不像XML那么广泛,不过JSON.org上提供很多语言的库
  • 如果你使用eval()来解析的话,会容易出现安全问题
尽管如此,JSON的优点还是很明显的。他是Ajax数据交互的很理想的数据格式。

JSONP (JSON-p)

如果你使用XMLHttpRequest来调用JSON的web服务,返回的数据可以通过JSON.parse()或者eval()来处理。你也可以使用Ajax组件来做脚本的插入,例如,将远程加载的脚本插入在DOM节点中,通过script标签调用:
1
2
3
var script = document.createElement("script");
script.src = "http://webservice.com/?a=1&b=2";
document.getElementsByTagName("head")[0].appendChild(script);
 
跟XMLHttpRequest不同,插入script标签可以在不同源的情况下获取其他服务的数据。这对于流量分析、书签工具、小插件、广告系统来说是很理想的选择。
不过,返回的JSON数据通常都是当做本地的代码立即执行。也不会赋值给变量,所以后面就再访问不到了。不过这个问题我们可以通过给网络服务传递一个callback参数来进行回调:
1
2
3
var script = document.createElement("script");
script.src = "http://webservice.com/?a=1&b=2&callback=MyDataHandler";
document.getElementsByTagName("head")[0].appendChild(script);
 
这时候,网络服务通常会返回一个包含在一个回调函数中的JSON数据,这就是JSONP,或者“JSON with padding”,看看代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
MyDataHandler([
    {
        title: "The Principles of Beautiful Web Design, 2nd Edition",
        url: "http://www.sitepoint.com/books/design2/",
        author: "Jason Beaird",
        publisher: "SitePoint",
        price: {
            currency: "USD",
            amount: 39.95
         }
     }
     ...
]);
 
在JSON对象下载完毕之后,作为参数传递给了MyDataHandler()方法。
JSON和JSONP已经是现在最流行的异步交互的数据格式了。但是在压缩传输数据大小的方面还是可以再研究的。RockUX会在后面讲到关于自定义数据返回。
看看这一系列其他的文章:
  • Ajax和WEB服务数据格式:XML SOAP HTML
  • Ajax和WEB服务数据格式:自定义返回格式
    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    评价:
    表情:
    验证码:点击我更换图片

    推荐图文

    • 在ASP.NET中使用AJAX的简单方法
    • 利用PHP+JavaScript打造AJAX搜索
    • jQuery实现网页精美幻灯片特效的21个实例
    • 建站吧收集10个优秀的jQuery幻灯片教程
    • 动态网站导航菜单:Javascript和jQuery导航菜单教程
    • 建站吧分享非常棒的国外的jQuery教程
    • AJAX JSF组件实现高性能的文件上载
    Alexa - 客户服务 - 联系方法 - 招聘信息 - 友情链接 - 网站地图 - TAG标签 - RSS订阅
    Copyright © 2010-2012 JZQ8.COM. 建站吧|建站去吧 版权所有
    冀ICP备09002514号
    冀ICP备09002514号 网络报警 企业法人营业执照 中国互联网协会 支付宝付款 网银在线付款