flex读取外部XML文件方式

在Flex中我们经常使用xml文件,因为Flex支持强大的E4X功能,读取xml相当简洁。

       总结一下常用的读取XML配置文件的方法:

      1. 使用Model标签形式

       首先声明Model标签,

       <mx:Model id="model" source="conf/configuration.xml"/>

       xml形如:

       <config>

                <username>hd</username>

               <psw>123456<psw>

       </config>

       那么,只需要在初始化事件中直接调用即可,例如:model.username, model.psw即可取到想要的值。

      2. 使用URLLoader

     var urlLoader:URLLoader = new URLLoader();
urlLoader.addEventListener(Event.COMPLETE, handleURLLoaderCompleted);
urlLoader.load(new URLRequest("conf/configuration.xml"));

    private function handleURLLoaderCompleted(event:Event):void {
var loader:URLLoader = event.target as URLLoader;
xml = XML(loader.data);

// dispatch Event here
}

    3. 使用HttpService

    <mx:HTTPService id="xmlReader" url="conf/configuration.xml"

                                                                  result="resultHandler(event)"/>      

   private function resultHandler(event:ResultEvent):void {
var dp:ArrayCollection = event.result as ArrayCollection;

       ......
}    

    在组件的createComplete事件中添加 xmlReader.send();语句调用Http请求。这种方法读取的XML文件格式是数组的形式,所以用ArrayCollection接收。如果想使用强大的E4X功能,需要在HTTPService对象中加上resultFormat="e4x"以XML的格式读取进来而不要转换为ArrayCollection。


注意:通过第一种方法加载进来的XML是在编译时编译到程序里面的,编译后再修改XML对程序无任何影响。所以还是用第二和第三种方法来加载外部XML文件。


  flex操作XML类型变量

 

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

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

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

view plaincopy to clipboardprint?
var myXML:XML =            
<books>              
<book name="flex tutorial">               
<price>30</price>               
<author>adobe</author>              
</book>               
<book name="sliverlight tutorial">            
<price>40</price>               
<author>microsoft</author>              
</book>               
<book name="java tutorial">               
<price>50</price>               
<author>sun</author>            
</book>               
<author>cyeric</author> //这是没有意义的一个节点,只是为了后面的演示    
</books>            
var myXML:XML =   
<books>   
<book name="flex tutorial">   
<price>30</price>   
<author>adobe</author>   
</book>   
<book name="sliverlight tutorial">   
<price>40</price>   
<author>microsoft</author>   
</book>   
<book name="java tutorial">   
<price>50</price>   
<author>sun</author>   
</book>   
<author>cyeric</author> //这是没有意义的一个节点,只是为了后面的演示
</books>   

 

 

1)查询  
使用"."操作符查询节点,使用"[]"访问指定索引的节点   
trace(myXML.book[0]) ;       

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

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

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

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

使用"@"操作符访问节点属性
trace(myXML.book[0].@name)

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

在查询过程中可以使用E4X的过滤功能,假如我现在只想查询价格在50块以下的书,我们可以这样
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元的那本书就没有打印出来了。


属性也可以过滤
trace(myXML.book.(@name=='flex tutorial'));

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

我们还可以把查询到的XML文本给改了,比如书店要把书都处理掉,然后叫卖:"5元5元一律5元"。
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对象,后面都将对这个对象进行操作        
var myXML:XML =   
<books>   
<book name="flex tutorial">   
<price>30</price>   
<author>adobe</author>   
</book>   
</books>   

添加元素/节点,使用insertChildBefore和insertChildAfter方法在某一位置添加元素/节点,appendChild和prependChild方法在最前和最后添加元素/节点
myXML.insertChildAfter(myXML.book[0],<newbook name="After"/>);    
myXML.insertChildBefore(myXML.book[0],<newbook name="Before"/>);    
myXML.appendChild(<newbook name="Append"/>);    
myXML.prependChild(<newbook name="Prepend"/>);    
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带来的便利
myXML.book[0].@date="2008";    
trace(myXML);   
输出
<books>
<book name="flex tutorial" date="2008">
<price>30</price>
<author>adobe</author>
</book>
</books>

修改XML对象
myXML.book[0].author="奥多比";    
trace(myXML);     

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

删除元素节点,属性等,使用delete关键字   
delete myXML.book[0].@name;      
delete myXML.book[0].author;      
delete myXML.book[0].price.text()[0];      
trace(myXML);      

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

 

在Flex中,XML是本地数据类型,就像Number或Boolean一样。

你可能感兴趣的:(flex读取外部XML文件方式)