zoukankan      html  css  js  c++  java
  • flash读取XML节点内容以及节点属性

    原文地址: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 += "----------------- ";
        for (i=0; i<newnode.childNodes.length; i++) {
         t.text += root.childNodes[j].childNodes[i].nodeName+":"+root.childNodes[j].childNodes[i].firstChild+" ";
        }
        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("第一层子节点数组是 "+newnode1+" ");
    var len1:Number = newnode1.length;
    //取得第一层子节点数组的长度。
    trace("第一层子节点数组长度是"+len1+" ");
    var newnode2:Array = root.firstChild.childNodes;
    //定位在根节点的首个子节点的子集,然后取得子集的数组长度,如果每个同级节点子集数目一样的话,这样定位就可以了,如果子集数目不等,要定位到子集最多的那个。
    trace("第二层子节点数组是 "+newnode2+" ");
    var len2:Number = newnode2.length;
    //知道几种课本
    trace("第二层子节点数组长度是"+len2+" ");
    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.年级+" ";//输出年级
       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+" ";
        //输出该年级的书名和定价
        }
       }
    }
    }
    输出:

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

  • 相关阅读:
    西交应用统计学(四)
    SPSS非参数检验
    并查集实现
    二叉树遍历非递归算法
    算法导论——渐近符号、递归及解法
    SPSS均值过程和T检验
    二维数组的查找及向函数传递二维数组问题
    printf()的格式
    C++ string类型的读写
    替换字符串中的空格
  • 原文地址:https://www.cnblogs.com/loyung/p/3267841.html
Copyright © 2011-2022 走看看