`
lvdou2518
  • 浏览: 7049 次
社区版块
存档分类
最新评论

详细介绍Flex中操作XML (转)

    博客分类:
  • Flex
阅读更多

http://www.iteye.com/blogs/tag/Flex

 

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

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

 

用一个例子来说明

  1. <root_node><!--这是一个根节点也是一个元素-->            
  2. <node attribute="value"><!--这是一个节点也是一个元素,其中包含有属性"attribute"-->             
  3. text node<!--这是一个文本节点-->             
  4. </node>              
  5. </root_node>            

 

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

 

二  Flex中创建XML对象

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

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

  1. var textXmlObj:XML = <test><element>text</element></test>;  

 

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

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

  1. var text_node:String = "text";   
  2. var textXmlObj:XML = <test><element>{text_node}</element></test>;  

 

 

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

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

  1. var myText:String = "text";   
  2. var str:String = "<test><element>"+ myText + "</element></test>";   
  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. <?xml version="1.0" encoding="utf-8"?>                                   
  2. <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute"                                 
  3.     creationComplete="unitRPC.send()">                              
  4.                                    
  5.     <mx:HTTPService id="unitRPC"                                    
  6.         url="xmlFile.xml"                              
  7.             result="unitRPCResult(event)"/>                             
  8.                                            
  9.     <mx:Script>                                  
  10.         <!--[CDATA[                             
  11.             import mx.rpc.events.ResultEvent;                          
  12.             private function unitRPCResult(event:ResultEvent):void {                           
  13.                                        
  14.             }                          
  15.         ]]-->                               
  16.     </mx:Script>                                 
  17. </mx:Application>                               

 

 

 

三 对XML对象进行处理

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

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

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

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

 

 

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

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

 

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

 

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

  1. trace(myXML..author);  

 

输出
<author>adobe</author>
<author>microsoft</author>
<author>sun</author>
<author>cyeric</author>

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

 

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

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

 

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

 

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

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

 

输出
<book name="flex tutorial">
  <price>30</price>
  <author>adobe</author>
</book>
<book name="sliverlight tutorial">
  <price>40</price>
  <author>microsoft</author>
</book>
价格为50元的那本书就没有打印出来了。


属性也可以过滤

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

 

输出
<book name="flex tutorial">
  <price>30</price>
  <author>adobe</author>
</book>

 

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

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

 

输出
<book name="flex tutorial">
  <price>5</price>
  <author>adobe</author>
</book>
<book name="sliverlight tutorial">
  <price>5</price>
  <author>microsoft</author>
</book>
<book name="java tutorial">
  <price>5</price>   
  <author>sun</author>   
</book>   

 

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

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

 

 

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

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


输出 
<books> 
  <newbook name="Prepend"/> 
  <newbook name="Before"/> 
  <book name="flex tutorial"> 
    <price>30</price> 
    <author>adobe</author> 
  </book> 
  <newbook name="After"/> 
  <newbook name="Append"/> 
</books> 
在第一个元素的前后各添加了一个元素 

 

 

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

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


输出 
<books> 
  <book name="flex tutorial" date="2008"> 
    <price>30</price> 
    <author>adobe</author> 
  </book> 
</books> 

 

 

修改XML对象 

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

 

<books>   
  <book name="flex tutorial">   
    <price>30</price>   
    <author>奥多比</author>   
  </book>   
</books>   
也很简单,修改属性的方法也是一样   

 

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

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

 

输出   
<books>   
  <book>     
    <price/>     
  </book>     
</books>     

 

 

四 在Flex中使用XML的例子

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

 

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

外部Xml文件 

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

 

Flex文件

  1. <?xml version="1.0" encoding="utf-8"?>                   
  2. <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"                   
  3.  layout="absolute"                 
  4.  creationComplete="init()">                 
  5.   <mx:Script>                
  6.   <!--[CDATA[                   
  7.       import mx.collections.ArrayCollection;                   
  8.       import mx.rpc.events.ResultEvent;                
  9.       //用于数据绑定的ArrayCollection                 
  10.       [Bindable]private var externalData:ArrayCollection = new ArrayCollection();                  
  11.                        
  12.       private function init():void {                   
  13.           //发送请求                   
  14.           myService.send();                
  15.       }                
  16.                            
  17.       private function resultHandler(event:ResultEvent):void {                 
  18.           //取得Xml对象中book节点的集合                  
  19.           externalData = event.result.books.book;                  
  20.       }//断点处                   
  21.   ]]-->                 
  22.   </mx:Script>                   
  23.   <!--创建Httpservice对象加载外部Xml-->                  
  24.   <mx:HTTPService id="myService"                
  25.       url="xmlFile.xml"                
  26.       result="resultHandler(event)"/>                   
  27.   <!--用于显示的list-->                   
  28.   <mx:List id="datalist" dataProvider="{externalData}" labelField="name"/>                           
  29. </mx:Application>               

 

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

 

 

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

外部XML文件

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

 

Flex文件

  1. <?xml version="1.0" encoding="utf-8"?>               
  2. <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"               
  3.  layout="absolute"             
  4.  creationComplete="myService.send()">               
  5.   <mx:HTTPService id="myService"            
  6.     url="xmlFile.xml"          
  7.     resultFormat="e4x"/>        
  8.                
  9. <mx:XMLListCollection id="booktreesrc"              
  10.     source="{myService.lastResult.category}"/>          
  11.                
  12. <mx:Tree id="bookTree"              
  13.     height="100%"          
  14.     dataProvider="{booktreesrc}"           
  15.     labelField="@name"/>        
  16.                        
  17. </mx:Application>           

 

画面显示

 

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

分享到:
评论

相关推荐

    Flex与JSON及XML的互操作

    - **Flex与XML的互操作**:Flex通过内置的XML解析功能,可以直接读取和解析XML数据,这使得从服务器获取XML格式的数据并将其展示在Flex应用中变得非常简便。例如,文章中提到的JSP文件生成的XML数据,可以直接被Flex...

    Flex:ArrayCollection转xml形式的实例

    另一方面,如果从服务器接收XML数据,也可以通过反向操作将XML转换为ArrayCollection,以便在Flex或Flash应用中使用。 在实际项目中,你可能还需要考虑更多细节,如XML的命名空间管理、属性的添加以及错误处理等。...

    Flex里解析XML数据

    Flex中的XML支持E4X,这是一种集成在AS3中的XML处理语法,使XML操作更加直观。E4X允许我们像处理JavaScript对象一样处理XML,例如: ```actionscript var items:Array = xml.root.item.*; for each (var item:XML ...

    flex 操作XML

    本篇将重点讲解如何在Flex中操作XML,包括从本地读取XML文件以及通过HttpServer获取远程XML数据。 1. **XML基础**: - XML是一种标记语言,它定义了一组规则来创建自己的标签,这些标签用于描述数据。 - XML文档...

    flex解析xml框架实例

    然后,我们可以使用XML对象的各种方法和属性来解析和操作XML文档。 XML解析的方法有很多,如访问节点、查询节点、遍历XML树等。例如,如果XML数据结构如下: ```xml &lt;item id="1"&gt;Item 1 &lt;item id="2"&gt;Item 2 ...

    flex解析xml

    总结,Flex解析XML文件主要通过XML和XMLList类,它们提供了丰富的API来操作XML数据。理解这些概念和方法,将有助于你在Flex应用中有效地处理和展示XML数据。无论是简单的数据展示还是复杂的交互逻辑,Flex都能通过...

    readxml flex加载xml文件

    XMLDocument类提供了另一种方式来加载和操作XML。与XMLLoader不同,XMLDocument可以直接加载XML字符串,或者从已存在的XMLNode实例中创建。以下是如何使用XMLDocument加载XML文件: ```actionscript var xmlRequest...

    FLEX操作XML&JSON

    【标题】: 使用FLEX操作XML和JSON 【概述】 在本文中,我们将探讨如何在Adobe Flex(现称为OpenFL)环境中处理XML和JSON数据。Flex是一种开源框架,允许开发人员使用ActionScript 3.0(AS3)和MXML来构建富互联网...

    flex 读XML 写XML 并保存为文件

    通过E4X,你可以像操作普通JavaScript对象一样操作XML。例如,获取XML中的某个节点值: ```actionscript var nodeValue:String = xml.root.node; ``` 二、XML写入 1. 创建XML对象:在创建XML对象时,可以直接通过...

    Flex操作XML

    以下将详细介绍Flex操作XML的几个关键步骤: 1. **加载XML**:Flex提供了`XML`类,用于解析和操作XML文档。你可以使用`URLLoader`加载XML文件,然后将加载的数据转换为`XML`对象。例如: ```actionscript var ...

    Flex中采用Flex-config.xml进行命令行的编译

    在Flex开发环境中,`flex-config.xml`文件是一个至关重要的配置文件,它允许开发者自定义Adobe Flex编译器的行为。这个文件通常位于项目的根目录下,或者在全局的Flex SDK安装路径中,对于命令行编译尤其重要。通过...

    flex 解析xml实例

    在Flex中,我们通常使用XML类来解析和操作XML文档。以下是一些关键步骤和知识点: 1. **创建XML对象**:在Flex中,你可以通过XML()构造函数创建一个XML对象,然后加载XML字符串或文件。例如: ```actionscript ...

    flex - xml操作

    ### Flex与XML操作详解 #### 一、E4X与ActionScript 3.0的集成 E4X(ECMAScript for XML)是ECMAScript标准的一个扩展,它被引入到ActionScript 3.0中,极大地简化了XML数据处理的过程。在Flash 5时,ActionScript...

    flex 操作xml 实现增删改查

    ### Flex操作XML实现增删改查 在Flex中操作XML数据是进行动态内容处理的关键技能之一。本篇文章将深入探讨如何使用Flex中的XML类来实现对XML数据的增、删、改、查功能。 #### 一、理解XML结构 XML(可扩展标记...

    ArcGIS Flex API 中的 Flex 技-xml解析

    示例代码来自`GeoRSSUtil.as`类,该类提供了一系列方法来解析GeoRSS格式的XML数据,其中`toGeometry`方法是核心,用于将XML中的地理坐标转换为`Geometry`对象。 ##### 4.2 `toGeometry`方法详解 - **GEOWGS命名...

    flex 解析xml文件 httpservice

    XML类是ActionScript 3.0中用于处理XML文档的主要工具,它提供了丰富的API来创建、解析和操作XML。例如,可以使用`XML.parse()`方法将XML字符串转换为XML对象,或者直接通过XML构造函数创建XML对象。 在Flex中,XML...

    动态绑定XML,实现flex树控件的绑定

    1. 创建XML数据:在.NET后端,你可以使用XMLDocument或者XDocument类来创建和操作XML。例如,生成一个表示树结构的XML文件,其中包含节点(节点可以有子节点)。 ```csharp var doc = new XDocument( new XElement...

    flex读取xml乱码的解决方法

    默认情况下,Flex使用Unicode编码(通常是UTF-8或UTF-16)来处理字符串,但如果XML文件使用的是其他编码,如GBK、BIG5等,那么在没有正确指定编码的情况下,Flex将无法正确解析XML中的字符,导致乱码出现。...

    flex上:简单的将xml内容生成文件存到本地的一个小例子

    XML对象提供了丰富的API,如addChild、toString等,使得在程序中操作XML变得简单。 2. **XML内容生成**: 在描述中提到的示例中,首先可能创建了一个XML对象,然后用字符串或其它数据结构填充XML内容。例如,可以...

Global site tag (gtag.js) - Google Analytics