`
hdxiong
  • 浏览: 375261 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Flex(ActionScript3)解析XML

    博客分类:
  • Flex
阅读更多

对于如下的一个XML文档,在flash中应该怎么读呢?

(图片来自kirupa.com)

按照Using XML in Flash CS3/AS3上的内容,包括了XML结构介绍等内容,在此我不再转述,对XML不怎么了解的话请先移步:XML 系列教程

这里我分三步描述flash读XML的基本方法,以及外延一个对带命名空间的XML的读取方法,如下目录:

1、加载XML文件;
2、读取XML的数据;
3、过滤数据;
4、读取带命名空间的XML数据;
5、处理gb2312编码的XML;

注:在这里的AS脚本都是在 Adobe Flash CS3 版本以上中进行编写,flex用户请自行添加修改相应的包引用。

下面开始第一部分,如何加载XML文件!

1、加载XML文件

在脚本编辑器中写入以下代码:

var xmlLoader:URLLoader = new URLLoader();
var xmlData:XML = null;
 
xmlLoader.addEventListener(Event.COMPLETE, LoadXML);
xmlLoader.load(new URLRequest("http://www.kirupa.com/net/files/sampleXML.xml"));
 
function LoadXML(e:Event):void {
  xmlData = new XML(e.target.data);
  trace(xmlData);
}

按Ctrl+Enter运行它,你会在输出窗口中看到整个XML的内容:
输出窗口
这里不进行代码解说,关于XML类,请查看:http://help.adobe.com/zh_TW/AS3LCR/Flash_10.0/XML.html

下面进入第2部分:如何读取XML数据。

2、读取XML数据

2.1直接读取XML数据

对XML数据的读取是十分简单的,不信请看:

function LoadXML(e:Event):void {
  xmlData = new XML(e.target.data);
  ParseBooks(xmlData);
}
 
function ParseBooks(bookInput:XML):void {
  trace("XML Output");
  trace("------------------------");
  trace(bookInput.Book);
}

可得到如何结果:

XML Output
------------------------
 
  Sir Arthur Conan Doyle
 
  F. Scott Fitzgerald
 
  Stephen E. Ambrose
 
  Stephen E. Ambrose

同样的,把trace的内容改为bookInput.Book.author,会得到下面的结果:

XML Output
------------------------
Sir Arthur Conan Doyle
F. Scott Fitzgerald
Stephen E. Ambrose
Stephen E. Ambrose

而trace(bookInput.Book.author.text());可得到:

XML Output
------------------------
Sir Arthur Conan DoyleF. Scott FitzgeraldStephen E. AmbroseStephen E. Ambrose

同样的,要读具体的节点,可以这样

trace(bookInput.Book.author.text()[0]);

可得到

XML Output
------------------------
Sir Arthur Conan Doyle

2.2、XML和XMLList

这里我们会用到另外一个类XMLList,这个类可以把XML对象作为数组的方式读取,可以方便地进行for each操作。

function ParseBooks(bookInput:XML):void {
  trace("XML Output");
  trace("------------------------");
  var authorList:XMLList = bookInput.Book.author;
  for each (var authorElement:XML in authorList) {
    trace(authorElement);
  }
}

 2.3历遍子元素

function ParseBooks(bookInput:XML):void {
  trace("XML Output");
  trace("------------------------");
  var bookChildren:XMLList = bookInput.Book.children();
  for each (var bookInfo:XML in bookChildren) {
    trace(bookInfo);
  }
}

结果如下:

XML Output
------------------------
Sherlock Holmes: Complete Novels and Stories, Vol 1
Sir Arthur Conan Doyle
The Great Gatsby
F. Scott Fitzgerald
Undaunted Courage
Stephen E. Ambrose
Nothing Like It In the World
Stephen E. Ambrose

同样的,我们可以用节点的.name()方法得知它的标签名:

function ParseBooks(bookInput:XML):void {
  trace("XML Output");
  trace("------------------------");
  var bookChildren:XMLList = bookInput.Book.children();
  for each (var bookInfo:XML in bookChildren) {
    if (bookInfo.name() == "author") {
      trace(bookInfo);
    }
  }
}

这样就可以得到所有author的值了。

2.4读取属性

历遍属性的方法:

function ParseBooks(bookInput:XML):void { 
  trace("XML Output"); 
  trace("------------------------"); 
  var bookAttributes:XMLList = bookInput.Book.attributes(); 
  for each (var bookISBN:XML in bookAttributes) { 
    trace(bookISBN); 
  } 
}

对于attributes,同样有一个.name()方法:

function ParseBooks(bookInput:XML):void { 
  trace("XML Output"); 
  trace("------------------------"); 
  var bookAttributes:XMLList = bookInput.Book.attributes(); 
  for each (var bookISBN:XML in bookAttributes) { 
    if (bookISBN.name() == "ISBN") { 
      trace(bookISBN); 
    } 
  } 
}

另外还有一种更直接的方法,直接用.attribute(“ISBN”) :

function ParseBooks(bookInput:XML):void { 
  trace("XML Output"); 
  trace("------------------------"); 
  var bookAttributes:XMLList = bookInput.Book.attribute("ISBN"); 
  for each (var bookISBN:XML in bookAttributes) { 
    trace(bookISBN); 
  } 
}

注意,这个.attribute(attributeName:*)方法不是.attributes()哦,少了个s的哦。

3、过滤数据

3.1过滤值

function ParseBooks(bookInput:XML):void { 
  trace("XML Output"); 
  trace("------------------------"); 
  var authorList:XMLList = bookInput.Book.(author == "Stephen E. Ambrose"); 
  trace(authorList); 
}

可得到:

XML Output
------------------------
<Book ISBN="0684826976">
  <title>Undaunted Courage</title>
  <author>Stephen E. Ambrose</author>
</Book>
<Book ISBN="0743203178">
  <title>Nothing Like It In the World</title>
  <author>Stephen E. Ambrose</author>
</Book>

所以在过滤之后,可以同样使用

var authorList:XMLList = bookInput.Book.(author == "Stephen E. Ambrose").title;

得到所有作者是Stephen E. Ambrose的书名了。

3.2过滤属性

function ParseBooks(bookInput:XML):void { 
  trace("XML Output"); 
  trace("------------------------"); 
  var bookList:XMLList = bookInput.Book.(@ISBN == "0743203178").title; 
  trace(bookList); 
}

我们还可以进行一些复杂的过滤:

function ParseBooks(bookInput:XML):void { 
  trace("XML Output"); 
  trace("------------------------"); 
  var bookList:XMLList = bookInput.Book.(author == "Stephen E. Ambrose" && title != "Nothing Like It In the World").title; 
  trace(bookList); 
}

4、读取带命名空间的XML数据

如果把上面的XML文件改一改,变成如下:

<Books xmlns:g="http://guitarbean.com/">
  <Book ISBN="0553212419">
    <title>Sherlock Holmes: Complete Novels and Stories, Vol 1</title>
    <author>Sir Arthur Conan Doyle</author>
  </Book>
  <Book ISBN="0743273567">
    <title>The Great Gatsby</title>
    <author>F. Scott Fitzgerald</author>
  </Book>
  <Book ISBN="0684826976">
    <title>Undaunted Courage</title>
    <author>Stephen E. Ambrose</author>
  </Book>
  <Book ISBN="0743203178">
    <title>Nothing Like It In the World</title>
    <author>Stephen E. Ambrose</author>
    <g:cost>XXXXXXX</g:cost>
  </Book>
</Books>

这时要用到Namespace类了:

function ParseBooks(bookInput:XML):void { 
  trace("XML Output"); 
  trace("------------------------");
  var g:Namespace = new Namespace("http://guitarbean.com/"); 
  trace(bookInput.Book.g::cost); 
}

可得到:

XML Output
------------------------
XXXXXXX

这里的双冒号(::)就是命名空间符,只要建立了一Namespace对象,XML对象便可直接用点运算符来操作了,相对的比较方便。

5、处理gb2312编码的XML

有的XML文件可能不是UTF8的,如在中国常用的gb2312编码,侧需要转码一下,这时要用到ByteArray类,在建立XML对象前统一处理下即可:

var xmlLoader:URLLoader = new URLLoader();
var xmlData:XML = null;
 
xmlLoader.addEventListener(Event.COMPLETE, LoadXML);
xmlLoader.load(new URLRequest("http://www.kirupa.com/net/files/sampleXML.xml"));
 
function LoadXML(e:Event):void {
  var BA:ByteArray = new ByteArray;
  BA.writeBytes((e.target as URLLoader).data);
  BA.position = 0;
 
  //把gb2312转为UTF8编码:
  var newData:String = BA.readMultiByte(BA.length,"gb2312");
  //然后才建立XML对象:
  xmlData = new XML(newData);
  trace(xmlData);
}

本文转自:http://blog.guitarbean.com/2009/12/actionscript3-reading-xml.html

分享到:
评论
1 楼 enjoyjava 2010-11-14  
同样的,我们可以用节点的.name()方法得知它的标签名:
function ParseBooks(bookInput:XML):void {
  trace("XML Output");
  trace("------------------------");
  var bookChildren:XMLList = bookInput.Book.children();
  for each (var bookInfo:XML in bookChildren) {
    if (bookInfo.name() == "author") {
      trace(bookInfo);
    }
  }
}
你这里写错了吧?我看文档里bookInfo.name().localName才能得到标签名。。。。。。

相关推荐

    Flex里解析XML数据

    本文将深入探讨如何在Flex中解析XML数据,以及相关的工具和技术。 1. XML基础 XML(Extensible Markup Language)是一种自定义标记语言,用于存储和传输结构化数据。它的结构清晰,易于人和机器阅读。XML文档由元素...

    flex解析xml框架实例

    本文将深入探讨如何使用Flex解析XML框架,结合HTTPService组件,实现从服务器接收并解析XML数据的实例。 首先,让我们理解Flex中的XML类。XML类是ActionScript 3.0中的一个核心类型,它提供了一种强大而灵活的方式...

    flex解析xml

    本文将深入探讨Flex如何解析XML文件。 首先,让我们了解一下XML(Extensible Markup Language)。XML是一种结构化数据语言,用于存储和传输数据,它的结构清晰,易于机器和人阅读。在Flex中,XML通常用于从服务器...

    flex 解析xml文件 httpservice

    本篇文章将深入探讨如何使用Flex解析XML文件,并通过HTTPService来读取XML内容,以及如何根据需求过滤字符串并获取所需值。 首先,让我们了解Flex中的XML类。XML类是ActionScript 3.0中用于处理XML文档的主要工具,...

    Flex与JSON及XML的互操作

    2. **解析XML**:接收到XML响应后,Flex应用使用`XML`类解析XML数据,将其转换为AS3对象。 3. **数据绑定**:将解析后的数据绑定到Flex应用的UI组件上,如数据网格或列表,以展示股票价格信息。 #### 结论 Flex与...

    flex 解析xml实例

    本实例将探讨如何在Flex中解析XML,以读取XML标签并获取信息。 首先,XML(eXtensible Markup Language)是一种结构化数据语言,它的主要特点是结构清晰、易于阅读和编写,并且可以被机器和人类同时理解。在Flex中...

    flex 读XML 写XML 并保存为文件

    1. 使用XML类:在Flex中,我们可以直接创建XML对象来解析XML文档。首先,我们需要导入`mx.utils.XMLUtil`库,然后使用`XMLUtil.parse()`方法将XML字符串转换为XML对象。例如: ```actionscript var xmlStr:String = ...

    ArcGIS Flex API 中的 Flex 技-xml解析

    对于ArcGIS Flex API而言,理解如何解析XML至关重要,尤其是在处理地理信息时。本文将详细介绍如何使用ArcGIS Flex API进行XML解析,并通过一个具体示例来阐述其应用场景。 #### 二、XML在ArcGIS Flex API中的重要...

    Flex之URLLoader加载XML

    1. `&lt;mx:Script&gt;` 标签内包含了ActionScript代码,用于处理加载和解析XML的过程。 - `import` 语句导入了必要的类,如 `mx.collections.ArrayCollection` 和 `mx.rpc.events.ResultEvent`。 - `public var loader:...

    Flex:ArrayCollection转xml形式的实例

    XML类允许我们创建、操作和解析XML文档。以下是一个简单的示例,展示如何将ArrayCollection转换为XML: ```actionscript import mx.collections.ArrayCollection; import flash.xml.XMLDocument; var ...

    flex 解析xml绑定到combobox点击按钮把combobox所选的数据添加到List

    1. **XML解析**:在Flex中,我们可以使用`mx:XML`组件或`flash.xml.XMLDocument`类来解析XML数据。XML是一种常见的数据格式,用于存储和传输结构化数据。在示例中,XML可能包含一系列可选项,这些选项将被用作...

    readxml flex加载xml文件

    XMLLoader是ActionScript 3中的一个类,专门用于加载和解析XML文档。使用XMLLoader,可以异步加载XML,这意味着主程序不会因为等待XML加载而阻塞。下面是一个简单的使用XMLLoader的例子: ```actionscript var ...

    Flex+ActionScript+JAVA等学习教程集合

    ActionScript还支持XML和JSON解析,使得与服务器的数据交换更为便捷。 2. **Flex与Java数据交互**:BlazeDS是Adobe提供的一个免费服务器端技术,用于在Flex客户端和Java服务器之间进行实时数据通信。通过BlazeDS,...

    flex用两种方法读取xml文件

    以下是如何使用HTTPService来获取并解析XML数据的步骤: (1)导入必要的库: ```actionscript import mx.rpc.http.HTTPService; import flash.events.Event; ``` (2)创建HTTPService实例,并配置URL和方法: ``...

    flex 操作XML

    综上所述,Flex中的XML操作涉及文件系统访问、网络通信、数据解析等多个方面,熟练掌握这些技能对于构建Flex应用至关重要。在实际项目中,根据具体需求灵活运用这些知识点,可以实现高效的数据管理和交换。

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

    3. 在Flex客户端接收XML:在Flex中,可以使用URLLoader类加载XML数据,然后使用XMLDecoder解析XML字符串为XML对象。 ```actionscript var urlLoader:URLLoader = new URLLoader(); urlLoader.dataFormat = ...

    flex读取试卷的xml文件 并做成考试系统

    3. 解析XML数据:加载完成后,可以使用`XML`类的方法和属性来解析XML数据。例如,获取根节点的子节点,遍历节点,获取属性值等。 接下来,让我们看看如何将XML数据转化为考试试卷。假设XML文件结构如下: ```xml ...

    Flex权威指南 flex3_actionscript_examples.zip

    《Flex权威指南》是针对Adobe Flex 3框架的一本深入解析书籍,主要涵盖了ActionScript 3.0在Flex开发中的应用。这本书通过丰富的实例来详细阐述Flex开发的关键技术和最佳实践,旨在帮助开发者全面掌握Flex 3的编程...

    flex外部读取xml

    本示例中,我们看到一个Flex应用通过使用ActionScript 3来从外部XML文件加载数据,并将这些数据用于创建图形界面元素。 首先,XML文件的结构对于正确解析至关重要。在示例中没有给出具体的XML文件内容,但我们可以...

Global site tag (gtag.js) - Google Analytics