加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Flex中操作XML

发布时间:2020-12-15 05:08:51 所属栏目:百科 来源:网络整理
导读:一? 在介绍Flex中操作XML之前,首先简单介绍下XML中的基本术语。 ???? 元素:XML中拥有开始标签和结束标签的这一块称为“元素”???? 节点:把XML元素与文本结合起来统称为节点???? 根节点:位于整个XML文当顶端的节点???? 文本节点:包含文本的节点???? 属性

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

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

?

用一个例子来说明

[xhtml]
  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文本赋给这个对象

[java]
  1. var?textXmlObj:XML?=?<test><element>text</element></test>;??
注意:这里等号右边的表达式不用加上引号,因为AS认识它,知道它是一个XML,如果加上引号就成了String类型了,编译也无法通过。

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

[java]
  1. var?text_node:String?=?"text";??
  2. var?textXmlObj:XML?=?<test><element>{text_node}</element></test>;??
2.创建一个XML对象,并在构造方法中传入字符串作为XML文本

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

[javascript]
  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

[javascript]
  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;如果这里看不懂代码没关系,后面将细致的介绍下面的这种处理方式

[javascript]
  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对象,后面都将对这个对象进行操作

[c-sharp]
  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)查询???
使用"."操作符查询节点,使用"[]"访问指定索引的节点???

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

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

[c-sharp]
  1. trace(myXML..author);??
输出
<author>adobe</author>
<author>microsoft</author>
<author>sun</author>
<author>cyeric</author>

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

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

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

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

[c-sharp]
  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元的那本书就没有打印出来了。


属性也可以过滤

[c-sharp]
  1. trace(myXML.book.(@name=='flex?tutorial'));??
输出
<book name="flex tutorial">
? <price>30</price>
? <author>adobe</author>
</book>

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

[c-sharp]
  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对象,后面都将对这个对象进行操作???

[xhtml]
  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方法在最前和最后添加元素/节点?

[javascript]
  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带来的便利?

[javascript]
  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对象?

[javascript]
  1. myXML.book[0].author="奥多比";???
  2. trace(myXML);?????
<books>???
? <book name="flex tutorial">???
??? <price>30</price>???
??? <author>奥多比</author>???
? </book>???
</books>???
也很简单,修改属性的方法也是一样???

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

[javascript]
  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文件?

[xhtml] view plain copy print ?
  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文件

[javascript] view plain copy print ?
  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文件

[javascript] view plain copy print ?
  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文件

[javascript] view plain copy print ?
  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>???????????

画面显示

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读