原文地址:http://hi.baidu.com/yqzdm/item/f95fd9d24679d916d90e44c9

一、xml的写法:

这里的xml只是在有限范围内的了解,限于写一些简单的用于flash使用的xml文本。太深奥的东西我也不懂。

例1:课本.xml

<?xml version="1.0" encoding="UTF-8"?>
<课本>
<书名>语文</书名>
<书名>数学</书名>
<书名>历史</书名>
<书名>音乐</书名>
</课本>

这是个很简单的xml文档。

如果想增加其他信息,可以继续修改这个xml文档:

<?xml version="1.0" encoding="UTF-8"?>
<课本>

<具体>
<书名>语文</书名>
<定价>5</定价>
</具体>

<具体>
<书名>数学</书名>
<定价>5.5</定价>
</具体>

<具体>
<书名>历史</书名>
<定价>6.5</定价>
</具体>

<具体>
<书名>音乐</书名>
<定价>4.5</定价>
</具体>

</课本>

看起来这个xml内容稍微有一点点实用的意思。

但是写法不止一种,比如:

<?xml version="1.0" encoding="UTF-8"?>
<课本>
<具体 书名="语文" 定价="5"/>
<具体 书名="数学" 定价="5.5"/>
<具体 书名="历史" 定价="6.5"/>
<具体 书名="音乐" 定价="4.5"/>
</课本>

这种看起来更直观些,它使用了属性/值对的方法。当标签没有文本节点时,尾标签可省略为</>.

属性可以通过attributes得到,节点名称通过nodeName得到,节点值通过nodeValue得到。

再开看一个xml文档结构,通过该结构来说对号入座的讲解:

这个图中文档结构来看,

<根></根>这一对标签所包含的部分,就是firstChild

其下有两对并列的<课本></课本>标签包含部分,这是firstChild.childNodes,是一个数组,第一个元素是firstChild.childNodes[0],第二个元素是firstChild.childNodes[1]。

拿firstChild.childNodes[0]来说,下一级又有子节点,firstChild.childNodes[0].childNodes表示,也就是

<n1 书名="语文">6</n1>
<n2 书名="数学">8</n2>
<n3 书名="英语">5</n3>
<n4 书名="美术">15</n4>

firstChild.childNodes[0].childNodes[0],或者firstChild.firstChild.firstChild,就来到了

<n1 书名="语文">6</n1>

n1是标签,也是节点,姑且叫它标签节点,节点名称(nodeName)是"n1"。6是文本,也是节点,叫文本节点,节点名称null,节点值(nodeValue)是6。这里两个节点并不是平级,6是n1的子级。 "书名"是属性(attributes),属性值是"语文"。

二、flash读取xml

xml文件名:课本.xml

<?xml version="1.0" encoding="UTF-8"?>
<课本>
<具体 >
<年级>一年级</年级>
<书名>语文</书名>
<定价>5</定价>
</具体>
<具体>
<年级>二年级</年级>
<书名>语文</书名>
<定价>6</定价>
</具体>
<具体>
<年级>三年级</年级>
<书名>历史</书名>
<定价>8</定价>
</具体>
</课本>

''''''''''''''''''''''''''''''''''''''''''''''''

flash文件名:l_xml.fla

var lx:XML = new XML();
lx.ignoreWhite = true;
lx.onLoad = function(s:Boolean) {
if (s) {

/*********************************************
先定位根节点root,再定位根节点的首节点。用for的双循环循环得到数据,显示在文本框中。
有时候真的是感觉很混乱,不过多用trace()测试一下就清楚了。
*********************************************/
   var root:XMLNode = lx.firstChild;
   var newnode:XMLNode = root.firstChild;
   for (j=0; j<root.childNodes.length; j++) {
    t.text += "-----------------\n";
    for (i=0; i<newnode.childNodes.length; i++) {
     t.text += root.childNodes[j].childNodes[i].nodeName+":"+root.childNodes[j].childNodes[i].firstChild+"\n";
    }
    t.text += "-----------------";
   }
} else {
   t.text = "cuo";
}
};
lx.load("课本11.xml");

''''''''''''''''''''''''''''''''

flash显示效果:

再做个练习:

书费.xml:

<?xml version="1.0" encoding="UTF-8"?>
<根>
<课本 年级="一年级">
<n1 书名="语文" >6</n1>
<n2 书名="数学" >8</n2>
<n3 书名="英语" >5</n3>
<n4 书名="美术" >15</n4>
</课本>
<课本 年级="二年级">
<n1 书名="语文" >7</n1>
<n2 书名="数学" >6</n2>
<n3 书名="英语" >9</n3>
</课本>
</根>

l_书费.fla:

var myxml:XML = new XML();
myxml.ignoreWhite = true;
myxml.onLoad = function(s) {
if (s) {
   readxml();
} else {
   t.text = "载入出错!";
}
};
myxml.load("书费.xml");
function readxml() {
var root:XMLNode = myxml.firstChild;
//声明根节点root
var newnode1:Array = root.childNodes;
//定位根节点下第一层子节点数组newnode1,相当于知道有几个年级。
trace("第一层子节点数组是\n"+newnode1+"\n");
var len1:Number = newnode1.length;
//取得第一层子节点数组的长度。
trace("第一层子节点数组长度是"+len1+"\n");
var newnode2:Array = root.firstChild.childNodes;
//定位在根节点的首个子节点的子集,然后取得子集的数组长度,如果每个同级节点子集数目一样的话,这样定位就可以了,如果子集数目不等,要定位到子集最多的那个。
trace("第二层子节点数组是\n"+newnode2+"\n");
var len2:Number = newnode2.length;
//知道几种课本
trace("第二层子节点数组长度是"+len2+"\n");
var 书名:String = newnode2[0].attributes.书名;
//测试一下,看看能否取得xml文档结构中的书名。
trace("你所找的书名是"+"“"+书名+"”");
//数学
var ttt = newnode1[0].childNodes[1].firstChild;
//测试一下,看看能否取得xml文档结构中的定价。
trace("该书定价是"+ttt);
//8
for (i=0; i<len1; i++) {
   t.text += newnode1[i].attributes.年级+"\n";//输出年级
   for (j=0; j<len2; j++) {
    var ttt:String = newnode1[i].childNodes[j].firstChild.toString();
    if (ttt !== undefined) {//保证该位置有内容才输出,未定义内容则不输出。
     t.text += newnode1[i].childNodes[j].attributes.书名+":"+newnode1[i].childNodes[j].firstChild+"\n";
    //输出该年级的书名和定价
    }
   }
}
}
输出:

如果解决了读取的问题,接下来的一个技术难点当然是分页的问题。这个难点还是先放一放,继续熟练xml的读取吧。

flash读取XML节点内容以及节点属性的更多相关文章

  1. (转载)读取xml中的指定节点的值

            /// <summary>         /// 读取xml中的指定节点的值        /// </summary>         private st ...

  2. 读取xml中的指定节点的值

    /// <summary> /// 读取xml中的指定节点的值 /// </summary> private string ReadXmlNode(string filenam ...

  3. Qt QtXml读取xml文件内容

    Qt QtXml读取xml文件内容 xml文件内容 <?xml version="1.0" encoding="UTF-8"?> <YG_RT ...

  4. dom4j读取XML文件内容

    <?xml version="1.0" encoding="UTF-8"?> <RESULT> <VALUE> <NO ...

  5. 读取xml文件内容到数据库

    前言 前言不搭后语·················· 内容 听某个大牛说他们的公司常常会涉及到从xml文件中读数据到写入到数据库,序列化的时候会遇到这这个问题,将要持久化的数据到xml文件存储起来, ...

  6. 通过Java读取xml文件内容

    读取XML中的内容就需要对XML进行解析,目前对XML进行解析的方法分为四种: 下面解析的方法是DOM4J,需要下载jar包dom4j:https://dom4j.github.io/ package ...

  7. 读取XML文件内容

    myeclipse中类的格式 上面中的RunMain.java为程序执行的入口,JdbcUtil.java为实体类,XmlDocumentUtil.java执行解释xml文件与获取里面的属性,程序所需 ...

  8. php读取xml文件内容,并循环写入mysql数据库

    <?php $dbconn = mysql_connect("localhost","root","root"); $db = mys ...

  9. JS通过ajax动态读取xml文件内容

    http://www.sharejs.com/codes/javascript/8178 HTML文件代码如下 <!DOCTYPE html> <html> <head& ...

随机推荐

  1. Selenium WebDriver对cookie进行处理绕过登录验证码

    现在几乎所有登录页面都会带一个验证码,做起自动化这块比较麻烦, 所以要绕过网站的验证码. 首先需要手动登录一次你的测试网站,去chrome的F12里获取这个网站的cookie信息,找到对应的保存登录信 ...

  2. HTML5 3D动画效果

    对以前来讲,3D动画拿到网页上展示是一件非常奢侈的事情,第一是浏览器不够先进,第二是大部分只能用flash实现伪3D.HTML5的出现,让实现网页3D动画变得非常简单,当然前提是你不要再使用像IE67 ...

  3. HDU 2083 简易版之最短距离 --- 水题

    HDU 2083 简易版之最短距离 /* HDU 2083 简易版之最短距离 */ #include <cstdio> #include <algorithm> using n ...

  4. POJ-2152 Fire (树形DP)

    题目大意:在一棵树中选出一些点,选每个点的代价为w(i),并且对于点 i ,在距离它lim(i)之内必须选一个点,使它作为 i 的依赖点.求最小代价. 题目分析:定义状态dp(u,k)表示使u为根节点 ...

  5. CentOS配置LAMP环境

    环境:CentOS 6.5 配置防火墙,开启80端口.3306端口 # Firewall configuration written by system-config-firewall # Manua ...

  6. NLTK中的词性

    NOUN n,VERB v ,ADJ a, ADV r, ADJ_SAT s     NOUN: [('s', ''), ('ses', 's'), ('ves', 'f'), ('xes', 'x' ...

  7. urllib2

    import urllib2response = urllib2.urlopen("http://www.baidu.com")print response.read() urlo ...

  8. ABBYY PDF Transformer+从文件选项中创建PDF文档的教程

    可使用OCR文字识别软件ABBYY PDF Transformer+从Microsoft Word.Microsoft Excel.Microsoft PowerPoint.HTML.RTF.Micr ...

  9. SQL Server 表所在的文件组

    SELECT  o.[name] ,-- o.[type], i.[name], i.[index_id],         f.[name] FROM    sys.indexes i        ...

  10. 半透明背景(兼容IE)

    在CSS3中有rgba属性,可以很方便的实现背景透明,但对于IE家族来说却不是那么容易实现: FireFox.chrome.opera.safari 凡是对支持CSS3且支持W3标准的浏览器都可以现实 ...