该教程转载来自于:http://blog.chinaunix.net/uid-14767524-id-2785506.html    【看到这边文章的位置,具体原作者未知】

经过一些排版的修改,其他内容没变。【版权属于原作者】



一  在介绍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.  
  9. loader.load(request);
  10. loader.addEventListener(Event.COMPLETE, onComplete);
  11.  
  12. function onComplete(event:Event):void
  13. {
  14. var loader:URLLoader = event.target as URLLoader;
  15. if (loader != null)
  16. {
  17. externalXML = new XML(loader.data);
  18. trace(externalXML.toXMLString());
  19. }
  20. else
  21. {
  22. trace("loader is not a URLLoader!");
  23. }
  24. }

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. <mx:Script>
  9. <!--[CDATA[
  10.  
  11. import mx.rpc.events.ResultEvent;
  12.  
  13. private function unitRPCResult(event:ResultEvent):void {
  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]) ;

输出

  1. <book name="flex tutorial">
  2. <price>30</price>
  3. <author>adobe</author>
  4. </book>

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

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

  1. trace(myXML..author);

输出

  1. <author>adobe</author>
  2. <author>microsoft</author>
  3. <author>sun</author>
  4. <author>cyeric</author>

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

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

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

输出

  1. flex tutorial

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

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

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

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

属性也可以过滤

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

输出

  1. <book name="flex tutorial">
  2. <price>30</price>
  3. <author>adobe</author>
  4. </book>

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

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

输出

  1. <book name="flex tutorial">
  2. <price>5</price>
  3. <author>adobe</author>
  4. </book>
  5. <book name="sliverlight tutorial">
  6. <price>5</price>
  7. <author>microsoft</author>
  8. </book>
  9. <book name="java tutorial">
  10. <price>5</price>
  11. <author>sun</author>
  12. </book>

属性过滤并获取

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <root>
  3. <publishIP>
  4. http://192.168.116.64:8998
  5. </publishIP>
  6. <url>
  7. <add key="getSystem" value="zhongxia"/>
  8. <add key="getSystem1" value="zhongxia1"/>
  9. <add key="getSystem2" value="zhongxia2"/>
  10. <add key="getSystem3" value="zhongxia3"/>
  11. <add key="getSystem4" value="zhongxia4"/>
  12. </url>
  13. </root>

Flex代码:

  1. xml.url.add.(@key=='getSystem').@value

结果:

  1. zhongxia

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);

输出

  1. <books>
  2. <newbook name="Prepend"/>
  3. <newbook name="Before"/>
  4. <book name="flex tutorial">
  5. <price>30</price>
  6. <author>adobe</author>
  7. </book>
  8. <newbook name="After"/>
  9. <newbook name="Append"/>
  10. </books>

在第一个元素的前后各添加了一个元素

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

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

输出

  1. <books>
  2. <book name="flex tutorial" date="2008">
  3. <price>30</price>
  4. <author>adobe</author>
  5. </book>
  6. </books>

修改XML对象

  1. myXML.book[0].author="奥多比";
  2. trace(myXML);
  1. <books>
  2. <book name="flex tutorial">
  3. <price>30</price>
  4. <author>奥多比</author>
  5. </book>
  6. </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);

输出

  1. <books>
  2. <book>
  3. <price/>
  4. </book>
  5. </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>

画面显示

另外,在指定元素前和后插入,在最前端和尾端插入

  1. var example:XML = <person/>;
  2. example.two = "";
  3. example.insertChildBefore(example.two, <one/>); //在two节点前插入one节点
  4. example.insertChildBefore(example.two, "在two节点前插入文字");
  5. example.insertChildAfter(example.two, <three/>); //在two节点后插入three节点
  6. example.prependChild(<start/>); //在最顶端插入start节点
  7. example.appendChild(<end/>); //在尾端插入end节点
  8. example.start = "start内容"; //向节点增加内容
  9. trace(example);
  10. /*
  11. 输出:
  12. <person>
  13. <start>start内容</start>
  14. <one/>
  15. 在two节点前插入文字
  16. <two/>
  17. <three/>
  18. <end/>
  19. </person>
  20. */

【转】【Flex】#010 操作XML文件(E4X)的更多相关文章

  1. Flex中操作XML的E4X方法

    用于处理 XML 的 E4X 方法 Flash Player 9 和更高版本,Adobe AIR 1.0 和更高版本   ECMAScript for XML 规范定义了一组用于使用 XML 数据的类 ...

  2. Asp.Net 操作XML文件的增删改查 利用GridView

    不废话,直接上如何利用Asp.NET操作XML文件,并对其属性进行修改,刚开始的时候,是打算使用JS来控制生成XML文件的,但是最后却是无法创建文件,读取文件则没有使用了 index.aspx 文件 ...

  3. Java操作XML文件 dom4j 篇

    在项目中,我们很多都用到了xml文件,无论是参数配置还是与其它系统的数据交互.今天就来讲一下Java 中使用dom4j来操作XML文件. 我们需要引入的包: //文件包 import java.io. ...

  4. PHP操作XML文件学习笔记

    原文:PHP操作XML文件学习笔记 XML文件属于标签语言,可以通过自定义标签存储数据,其主要作用也是作为存储数据. 对于XML的操作包括遍历,生成,修改,删除等其他类似的操作.PHP对于XML的操作 ...

  5. Qt之QDomDocument操作xml文件-模拟ini文件存储

    一.背景 不得不说Qt是一个很强大的类库,不管是做项目还是做产品,Qt自身封装的东西就已经非常全面了,我们今天的这篇文章就是模拟了Qt读写ini文件的一个操作,当然是由于一些外力原因,我们决定自己来完 ...

  6. JAVA中通过Jaxp操作XML文件基础

    Java中有多种方式操作XML文件,目前讲一讲以SUN公司提供的DocumentBuilderFactory工厂类对象操作XML. 使用XML基本操作就是需要CRUD(增删改查),那么首先通过一个查询 ...

  7. WebAPI调用笔记 ASP.NET CORE 学习之自定义异常处理 MySQL数据库查询优化建议 .NET操作XML文件之泛型集合的序列化与反序列化 Asp.Net Core 轻松学-多线程之Task快速上手 Asp.Net Core 轻松学-多线程之Task(补充)

    WebAPI调用笔记   前言 即时通信项目中初次调用OA接口遇到了一些问题,因为本人从业后几乎一直做CS端项目,一个简单的WebAPI调用居然浪费了不少时间,特此记录. 接口描述 首先说明一下,基于 ...

  8. C#操作xml文件:使用XmlDocument 实现读取和写入

    XML文件是一种常用的文件格式,例如WinForm里面的app.config以及Web程序中的web.config文件,还有许多重要的场所都有它的身影.Xml是Internet环境中跨平台的,依赖于内 ...

  9. 利用XmlDocument操作XML文件

    利用XmlDocument可以方便的操作XML文件. .操作XML文件基本方法 ()添加对System.Xml的引用,并使用using语句添加引用: ()假设要读取的XML文件如下: <?xml ...

随机推荐

  1. Node.js进程管理之子进程

    一.理论 之前看多进程这一章节时发现这块东西挺多,写Process模块的时候也有提到,今天下午午休醒来静下心来好好的看了一遍,发现也不是太难理解. Node.js是单线程的,对于现在普遍是多处理器的机 ...

  2. centos 6.5安装docker

    安装linux,需要系统内核为3.x以上,如果centos版本为7以下,先升级系统内核 1.关闭selinux setenforce 0 sed -i '/^SELINUX=/c\SELINUX=di ...

  3. [转]Using TRY...CATCH in Transact-SQL

    本文转自:https://technet.microsoft.com/en-us/library/ms179296(v=sql.105).aspx Using TRY...CATCH in Trans ...

  4. Java学习--javabean

  5. Caused by: org.hibernate.HibernateException: identifier of an instance of ... is alterde from

    Caused by: org.hibernate.HibernateException: identifier of an instance of ... is alterde from     Hi ...

  6. Android Studio 1.1.0汉化初步出炉!

    我找到去年12月国人汉化的版本,然后迁移上来的.实测支持Android window最新版(1.1.0) 项目分4部分:1压缩好的:2文本分析器:3原生的语言包:4原版语言包备份 现在一些新增的项目没 ...

  7. Dijkstra Java

    https://leetcode.com/problems/network-delay-time/ /* Java program to find a Pair which has maximum s ...

  8. php 多次导入文件导致 Cannot redeclare class

    定义了类A b.php中导入了A c.php中导入了b.php c.php中导入A会报错:

  9. 浅谈脚本化css(三)之方块运动函数

    我们可以写一个让小方块运动的函数: div#demo { width: 100px; ; position: absolute; ; ; } var div = document.getElement ...

  10. 阿里云 CentOS7安装redis4.0.9并开启远程访问

    1 安装redis编译的c环境 yum install gcc-c++ redis是c语言开发的,安装redis需要先将官网下载的源码进行编译,编译依赖gcc环境. 如果没有gcc环境,需要安装gcc ...