AS3 对JSON的读取和发送

JSON(JavaScript Object Notation),是一种轻量级的数据交换格式,易于解析和生成,也易于阅读和编写。ajax的模式和构架被大量网站应用,JSON作为数据传输会是个首选。

虽然AS3对XML的解析已经很好了,但XML作为数据传输数据量大,服务器负担会过重。JSON本身的结构就简单易于理解,它的特点就是数据量小,数据的结构清晰。

下面说下as3对JSON的获取和发送(PS:http://code.google.com/p/as3corelib/  可以下载到JSON的类库):

Json代码:

 
[{ "type" : "pic" , "num" : "1" },  
{ "type" : "text" , "num" : "2" },  
{ "type" : "swf" , "num" : "3" },  
{ "type" : "html" , "num" : "4" }]


ActionScript代码:

[plain]  view plain copy
  1. package {  
  2. import com.adobe.serialization.json.JSON;  
  3.   
  4. import flash.display.Sprite;  
  5. import flash.events.Event;  
  6. import flash.net.URLLoader;  
  7. import flash.net.URLRequest;  
  8.   
  9. public class getJSON extends Sprite {  
  10.       public function getJSON() {  
  11.   
  12.       var urlLoader:URLLoader = new URLLoader();  
  13.   
  14.       urlLoader.load(new URLRequest( “http://127.0.0.1/json.php” ));//这里是你要获取JSON的路径  
  15.       urlLoader.addEventListener(Event.COMPLETE, decodeJSONHandler);  
  16. }  
  17. private function decodeJSONHandler(event:Event):void {  
  18.         var jsonArray:Array = JSON.decode( URLLoader( event.target ).data );  
  19.          //获取数组中存储的数据  
  20.          for (var i=0; i<jsonArray.length; i++) {  
  21.         trace( jsonArray[i].type );  
  22.    }  
  23. }  
  24. }  
  25. }  

以上是获取JSON,使用到的是Decode方法,接下来使用Json里的另一个方法Encode,发送Json:

ActionScript代码:

[plain]  view plain copy
  1. package {  
  2.    import com.adobe.serialization.json.JSON;  
  3.   
  4.    import flash.display.Sprite;  
  5.    import flash.events.Event;  
  6.    import flash.net.*;  
  7.   
  8. public class sendJSON extends Sprite {  
  9.      public function sendJSON() {  
  10.                var objectArray: Array = new Array({"type":"pic","num":"1"},  {"type":"text","num":"2"},  {"type":"swf","num":"3"},  {"t                 ype":"html","num":"4"});//这里是要发送的数据,可以直接写,也可以是由其他方法生成,不过要注意格式。  
  11.           sendjson( objectArray);  
  12.      }  
  13.      private function sendjson( array : Array ):void {  
  14.          var jsonString : String = JSON.encode(array);  
  15.   
  16.          var urlVariables:URLVariables = new URLVariables();  
  17.          urlVariables.json = jsonString;  
  18.   
  19.          var urlRequest:URLRequest = new URLRequest(http://127.0.0.1/json.php); //接收数据。  
  20.          urlRequest.method = URLRequestMethod.POST;  
  21.          urlRequest.data = urlVariables;  
  22.   
  23.          var urlLoader:URLLoader = new URLLoader();  
  24.          urlLoader.addEventListener(Event.COMPLETE, onURLLoaderCompleteEvent);  
  25.          urlLoader.load(urlRequest);  
  26.       }  
  27.     private function onURLLoaderCompleteEvent( event: Event ):void {  
  28.          var xml:XML = new XML(event.target.data);  
  29.          trace(xml);  
  30.     }  
  31.     }  
  32.  }  


文章转自:http://www.cnblogs.com/deasonguan/archive/2011/07/21/2112615.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值