Json 的AS3.0解析类

[url=http://code.google.com/p/as3corelib/]json解析类下载地址: [/url]    http://code.google.com/p/as3corelib/

 

  其实在AS中使用json其实并不是一个必须或是很好的选择,因为AS对xml的解析已经很不错了,但是为什么可以考虑使用json呢,有以下几点:
  json是介于单纯的文本方式(如:
  firstName=Brett&amp;lastName=McLaughlin&email=brett@newInstance.com)和xml(<request><firstName>Brett</firstName><lastName>McLaughlin</lastName><email>brett@newInstance.com</email></request>)中间的一种格式,他具有文本和xml的中性优势:数据量小和清晰的数据格式。
  json是JavaScriptObjectNotation的简写,那么意思就是说他是来自于javascript的东西。因为现在ajax的流行,大部分网站会采用ajax的模式和构架,那么json会是一个数据传输的首选(文本方式太简单,要是大数据量的时候无法理解,xml的方式数据量大,在解析的时候会增加服务器负担),那么要是一个网站从ajax构架的基础上出一个flex/flash版的界面的时候使用json会最少地减少服务器端的程序改动。
  服务器端现在有成熟的JSON解析代码(因为JSON运用太广泛了),那么在开发的时候也不用担心服务器端的解析。
  ps:我怎么只能想到上面三点啊,会不会理由太少了?
  JSON是什么?
  简单JSON示例
  程序代码
  //按照最简单的形式,可以用下面这样的JSON表示名称/值对:
  {"firstName":"Brett"}
  //这个示例非常基本,而且实际上比等效的纯文本名称/值对占用更多的空间:
  firstName=Brett
  //但是,当将多个名称/值对串在一起时,JSON就会体现出它的价值了。首先,可以创建包含多个名称/值对的记录,比如:
  {"firstName":"Brett","lastName":"McLaughlin","email":"brett@newInstance.com"}
  从语法方面来看,这与名称/值对相比并没有很大的优势,但是在这种情况下JSON更容易使用,而且可读性更好。例如,它明确地表示以上三个值都是同一记录的一部分;花括号使这些值有了某种联系。
  值的数组
  当需要表示一组值时,JSON不但能够提高可读性,而且可以减少复杂性。例如,假设您希望表示一个人名列表。在XML中,需要许多开始标记和结束标记;如果使用典型的名称/值对(就像在本系列前面文章中看到的那种名称/值对),那么必须建立一种专有的数据格式,或者将键名称修改为person1-firstName这样的形式。
  程序代码
  //如果使用JSON,就只需将多个带花括号的记录分组在一起:
  {"people":[
  {"firstName":"Brett","lastName":"McLaughlin","email":"brett@newInstance.com"},
  {"firstName":"Jason","lastName":"Hunter","email":"jason@servlets.com"},
  {"firstName":"Elliotte","lastName":"Harold","email":"elharo@macfaq.com"}
  ]}
  这不难理解。在这个示例中,只有一个名为people的变量,值是包含三个条目的数组,每个条目是一个人的记录,其中包含名、姓和电子邮件地址。上面的示例演示如何用括号将记录组合成一个值。当然,可以使用相同的语法表示多个值(每个值包含多个记录):
  程序代码
  {"programmers":[
  {"firstName":"Brett","lastName":"McLaughlin","email":"brett@newInstance.com"},
  {"firstName":"Jason","lastName":"Hunter","email":"jason@servlets.com"},
  {"firstName":"Elliotte","lastName":"Harold","email":"elharo@macfaq.com"}
  ],
  "authors":[
  {"firstName":"Isaac","lastName":"Asimov","genre":"sciencefiction"},
  {"firstName":"Tad","lastName":"Williams","genre":"fantasy"},
  {"firstName":"Frank","lastName":"Peretti","genre":"christianfiction"}
  ],
  "musicians":[
  {"firstName":"Eric","lastName":"Clapton","instrument":"guitar"},
  {"firstName":"Sergei","lastName":"Rachmaninoff","instrument":"piano"}
  ]
  }
  这里最值得注意的是,能够表示多个值,每个值进而包含多个值。但是还应该注意,在不同的主条目(programmers、authors和musicians)之间,记录中实际的名称/值对可以不一样。JSON是完全动态的,允许在JSON结构的中间改变表示数据的方式。
  在处理JSON格式的数据时,没有需要遵守的预定义的约束。所以,在同样的数据结构中,可以改变表示数据的方式,甚至可以以不同方式表示同一事物。
  ps:以上例子都是来自http://www.ibm.com/developerworks/cn/web/wa-ajaxintro10/,掌握Ajax,自己懒,看人家有就顺便用了
  下面就介绍一下adobe的官方的json类的用法
  下面是教程,比较简单:
  1、服务器端来的json
  怎么样获得服务器端的json我就不说了吧(就是通讯),那么得到的应该是一个字符串,存入变量serverJSON,使用方式如下:
  程序代码
  importjson.*;
  //json格式字符串存入变量:serverJSON;
  varserverJSON:String='{"programmers":[{"firstName":"Brett","lastName":"McLaughlin","email":"brett@newInstance.com"},{"firstName":"Jason","lastName":"Hunter","email":"jason@servlets.com"},{"firstName":"Elliotte","lastName":"Harold","email":"elharo@macfaq.com"}],"authors":[{"firstName":"Isaac","lastName":"Asimov","genre":"sciencefiction"},{"firstName":"Tad","lastName":"Williams","genre":"fantasy"},{"firstName":"Frank","lastName":"Peretti","genre":"christianfiction"}],"musicians":[{"firstName":"Eric","lastName":"Clapton","instrument":"guitar"},{"firstName":"Sergei","lastName":"Rachmaninoff","instrument":"piano"}]}'
  //开始使用
  varjson:Object=newObject();
  json=JSON.decode(serverJSON);
  trace(json.programmers[0].firstName);//输出:Brett;
  json就是一个对象了,简单吧。
  不是吧这么简单。其实转变后就成为一个对象了,可以通过点语法来访问这些值了。XML靠边去。
  2、本地对象做成JSON
  你要是能自己拼出JSON字符串也可以,不过我们是在面向对象的世界啊,那么我们都是对象啊,到时候对象直接就可以来用了。
  举一个例子:
  程序代码
  importjson.*;
  varmyObject:Object=newObject();
  myObject.ab="adfsdf";
  myObject.cd=Math.random();
  trace(JSON.encode(myObject));//输出:{"ab":"adfsdf","cd":0.0599129400216043}
  这样就可以给服务器了。
  总结:就两个方法,JSON.decode(String),JSON.encode(Object),有这么简单的方式实现传输量小,而且简单的数据格式,我们为什么还不用呢?
  其实XML自然也有他自己的强势,当一个结构复杂的数据结构出现的时候,这个时候JSON就很难搞定了,XML就是首选了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值