Chinaunix首页 | 论坛 | 博客
  • 博客访问: 360794
  • 博文数量: 100
  • 博客积分: 2586
  • 博客等级: 少校
  • 技术积分: 829
  • 用 户 组: 普通用户
  • 注册时间: 2008-04-09 15:20
个人简介

我是一个Java爱好者

文章分类

全部博文(100)

文章存档

2014年(2)

2013年(7)

2012年(2)

2010年(44)

2009年(28)

2008年(17)

我的朋友

分类: Java

2010-02-01 19:15:23

一  在介绍Flex中操作XML之前,首先简单介绍下XML中的基本术语。    

元素:XML中拥有开始标签和结束标签的这一块称为“元素”    
节点:把XML元素与文本结合起来统称为节点    
根节点:位于整个XML文当顶端的节点    
文本节点:包含文本的节点    
属性:元素的组成部分,以键/值形式放在元素标签内  

 

用一个例子来说明

  1. <root_node>            
  2. <node attribute="value">             
  3. text node             
  4. node>              
  5. root_node>            

XML简单介绍完了;之后,将分别介绍XML对象的创建,XML对象的处理以及XML对象的运用。

 

二  Flex中创建XML对象

Flex中创建XML对象的方法有很多种,可以根据该XML对象的用途来决定使用哪种方法

1.创建一个XML对象,直接把XML文本赋给这个对象

  1. var textXmlObj:XML = text;  

注意:这里等号右边的表达式不用加上引号,因为AS认识它,知道它是一个XML,如果加上引号就成了String类型了,编译也无法通过。

当然也可以动态的决定XML文本中的内容,用"{变量}"的方式插入到XML文本中。

  1. var text_node:String = "text";   
  2. var textXmlObj:XML = {text_node};  

 

2.创建一个XML对象,并在构造方法中传入字符串作为XML文本

我们平时在编程工作中,往往会以字符串的方式得到一个XML文本,这个时候就可以使用XML的构造方法来创建一个XML对象。

  1. var myText:String = "text";   
  2. var str:String = ""+ myText + "";   
  3. var textXmlObj:XML = new XML(str);  

 

3.从外部加载XML对象

对于比较大一点的XML文本来说,从外部加载无疑是最好的方式了,因为如果硬写在程序中,就算是对XML对象进行最简单的修改都是一个大灾难。

外部加载这里介绍2种方式

1)如果你不是在Flex中开发而只是在比如Flash CS3中开发的话,可以使用下面的这种方法来加载外部XML

  1. import flash.events.Event;             
  2. import flash.net.URLLoader;            
  3. import flash.net.URLRequest;               
  4.                
  5. var externalXML:XML;               
  6. var loader:URLLoader = new URLLoader();            
  7. var request:URLRequest = new URLRequest("xmlFile.xml");            
  8. loader.load(request);              
  9. loader.addEventListener(Event.COMPLETE, onComplete);               
  10.                
  11. function onComplete(event:Event):void              
  12. {              
  13.     var loader:URLLoader = event.target as URLLoader;               
  14.     if (loader != null)             
  15.     {               
  16.         externalXML = new XML(loader.data);             
  17.         trace(externalXML.toXMLString());               
  18.     }               
  19.     else            
  20.     {               
  21.         trace("loader is not a URLLoader!");            
  22.     }               
  23. }             

 

2) 如果是在Flex开发环境中就可以使用HttpService来加载外部的XML;如果这里看不懂代码没关系,后面将细致的介绍下面的这种处理方式

  1. "1.0" encoding="utf-8"?>                                   
  2. "" layout="absolute"                                 
  3.     creationComplete="unitRPC.send()">                              
  4.                                    
  5.     "unitRPC"                                    
  6.         url="xmlFile.xml"                              
  7.             result="unitRPCResult(event)"/>                             
  8.                                            
  9.                                       
  10.                                        
  11.                                      
  12.                                

 

 

三 对XML对象进行处理

在介绍XML对象的处理之前,介绍一个扩展语言"E4X",E4X大大简化了传统对XML的操作方式(如DOM接口)。

你会发现在程序中E4X操作XML是如此的简单,懒人们都乐坏了。

这里先给出一个XML对象,后面都将对这个对象进行操作

  1. var myXML:XML =            
  2.               
  3.   "flex tutorial">               
  4.     30               
  5.     adobe              
  6.                  
  7.   "sliverlight tutorial">            
  8.     40               
  9.     microsoft              
  10.                  
  11.   "java tutorial">               
  12.     50               
  13.     sun            
  14.                  
  15.   cyeric //这是没有意义的一个节点,只是为了后面的演示    
  16.             

 

1)查询   
使用"."操作符查询节点,使用"[]"访问指定索引的节点   

  1. trace(myXML.book[0]) ;     

输出   
   
  30   
  adobe   
   
输出内容说明,得到了第一个子节点;另外,如果我们想查询所有book节点的话只需要把[0]去掉就可以了。  

 

使用".."操作符访问所有以该标签命名的节点,而忽略节点的上下关系,注意最后那个节点

  1. trace(myXML..author);  

输出
adobe
microsoft
sun
cyeric

可以看到,不管author位于哪个位置,都打印了出来

 

使用"@"操作符访问节点属性

  1. trace(myXML.book[0].@name)  

输出
flex tutorial
第一个子节点的name属性就被打印了出来
以上这4个操作符号".","[]","..","@" 即为最常用的4个E4X操作符,简单吧,下面就循序渐进。

 

在查询过程中可以使用E4X的过滤功能,假如我现在只想查询价格在50块以下的书,我们可以这样

  1. trace(myXML.book.(price<50));  

输出

  30
  adobe


  40
  microsoft

价格为50元的那本书就没有打印出来了。


属性也可以过滤

  1. trace(myXML.book.(@name=='flex tutorial'));  

输出

  30
  adobe

 

我们还可以把查询到的XML文本给改了,比如书店要把书都处理掉,然后叫卖:"5元5元一律5元"。

  1. trace(myXML.book.(price=5));  

输出

  5
  adobe


  5
  microsoft


  5   
  sun   
   

 

2) 修改,修改XML对象包括修改,添加和删除操作   
虽然在介绍查询的时候介绍过可以在查询到XML文本的时候把它的内容给修改了。   
   
这里先给出一个XML对象,后面都将对这个对象进行操作   

  1. var myXML:XML =      
  2. <books>      
  3.   <book name="flex tutorial">      
  4.     <price>30price>      
  5.     <author>adobeauthor>      
  6.   book>      
  7. books>     

 

添加元素/节点,使用insertChildBefore和insertChildAfter方法在某一位置添加元素/节点,appendChild和prependChild方法在最前和最后添加元素/节点 

  1. myXML.insertChildAfter(myXML.book[0],"After"/>);    
  2. myXML.insertChildBefore(myXML.book[0],"Before"/>);    
  3. myXML.appendChild("Append"/>);    
  4. myXML.prependChild("Prepend"/>);    
  5. trace(myXML);   

输出 
 
   
   
   
    30 
    adobe 
 
 
   
   
 
在第一个元素的前后各添加了一个元素 

 

添加属性,直接使用E4X带来的便利 

  1. myXML.book[0].@date="2008";    
  2. trace(myXML);   

输出 
 
   
    30 
    adobe 
 
 
 

 

修改XML对象 

  1. myXML.book[0].author="奥多比";    
  2. trace(myXML);     

   
     
    30   
    奥多比   
 
   
   
也很简单,修改属性的方法也是一样   

 

删除元素节点,属性等,使用delete关键字   

  1. delete myXML.book[0].@name;      
  2. delete myXML.book[0].author;      
  3. delete myXML.book[0].price.text()[0];      
  4. trace(myXML);     

输出   
   
       
         
 
     
     

 

 

四 在Flex中使用XML的例子

大的XML文档用来显示数据或者显示列表的情况比较多,比如显示数据时作为Datagrid的数据源,或者为List,Combobox,Tree等的显示列表。

 

当我们使用List或者Combobox的时候,往往会把XML对象转换为ArrayCollection对象,看下面的例子

外部Xml文件 

  1. <books>                      
  2.     <book name="flex tutorial">                  
  3.         <price>30price>              
  4.         <author>adobeauthor>             
  5.     book>                  
  6.     <book name="air tutorial">                   
  7.         <price>40price>              
  8.         <author>adobeauthor>             
  9.     book>                  
  10.     <book name="java tutorial">                  
  11.         <price>50price>              
  12.         <author>sunauthor>               
  13.     book>                  
  14. books>                    

Flex文件

  1. "1.0" encoding="utf-8"?>                   
  2. ""                   
  3.  layout="absolute"                 
  4.  creationComplete="init()">                 
  5.                   
  6.                    
  7.                      
  8.                     
  9.   "myService"                
  10.       url="xmlFile.xml"                
  11.       result="resultHandler(event)"/>                   
  12.                      
  13.   "datalist" dataProvider="{externalData}" labelField="name"/>                           
  14.                

将上面的代码以debug模式执行,程序停在断点处,在variables视图中我们可以很清晰的看到程序HttpService对象在加载外部XML后已经把它转换成了ArrayCollection对象,如下图。这样就可以很轻松的将数据源绑定到显示列表对象List中。

 

 

另外一种情况,当我们使用Tree组件的时候,需要在HTTPService对象中加上resultFormat="e4x"以XML的格式读取进来而不要转换为ArrayCollection。

外部XML文件

  1.       
  2. "RIA">    
  3.     "flex tutorial" price="30" author="adobe">   
  4.           
  5.     "air tutorial" price="40" author="adobe">     
  6.           
  7.           
  8. "Java">           
  9.     "java tutorial" price="50" author="sun">      
  10.           
  11.           
  12.         

Flex文件

  1. "1.0" encoding="utf-8"?>               
  2. ""               
  3.  layout="absolute"             
  4.  creationComplete="myService.send()">               
  5.   "myService"            
  6.     url="xmlFile.xml"          
  7.     resultFormat="e4x"/>        
  8.                
  9. "booktreesrc"              
  10.     source="{myService.lastResult.category}"/>          
  11.                
  12. "bookTree"              
  13.     height="100%"          
  14.     dataProvider="{booktreesrc}"           
  15.     labelField="@name"/>        
  16.                        
  17.            

画面显示

 

另外,在指定元素前和后插入,在最前端和尾端插入
var example:XML = ;
example.two = "";
example.insertChildBefore(example.two, ); //在two节点前插入one节点
example.insertChildBefore(example.two, "在two节点前插入文字");
example.insertChildAfter(example.two, ); //在two节点后插入three节点
example.prependChild(); //在最顶端插入start节点
example.appendChild(); //在尾端插入end节点
example.start = "start内容"; //向节点增加内容
trace(example);
/*
输出:

  start内容
 
  在two节点前插入文字
 
 
 

*/

阅读(9923) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~