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 += "-----------------\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节点内容以及节点属性的更多相关文章
- (转载)读取xml中的指定节点的值
/// <summary> /// 读取xml中的指定节点的值 /// </summary> private st ...
- 读取xml中的指定节点的值
/// <summary> /// 读取xml中的指定节点的值 /// </summary> private string ReadXmlNode(string filenam ...
- Qt QtXml读取xml文件内容
Qt QtXml读取xml文件内容 xml文件内容 <?xml version="1.0" encoding="UTF-8"?> <YG_RT ...
- dom4j读取XML文件内容
<?xml version="1.0" encoding="UTF-8"?> <RESULT> <VALUE> <NO ...
- 读取xml文件内容到数据库
前言 前言不搭后语·················· 内容 听某个大牛说他们的公司常常会涉及到从xml文件中读数据到写入到数据库,序列化的时候会遇到这这个问题,将要持久化的数据到xml文件存储起来, ...
- 通过Java读取xml文件内容
读取XML中的内容就需要对XML进行解析,目前对XML进行解析的方法分为四种: 下面解析的方法是DOM4J,需要下载jar包dom4j:https://dom4j.github.io/ package ...
- 读取XML文件内容
myeclipse中类的格式 上面中的RunMain.java为程序执行的入口,JdbcUtil.java为实体类,XmlDocumentUtil.java执行解释xml文件与获取里面的属性,程序所需 ...
- php读取xml文件内容,并循环写入mysql数据库
<?php $dbconn = mysql_connect("localhost","root","root"); $db = mys ...
- JS通过ajax动态读取xml文件内容
http://www.sharejs.com/codes/javascript/8178 HTML文件代码如下 <!DOCTYPE html> <html> <head& ...
随机推荐
- UI学习笔记---第一天
一.iOS概述 iOS是Apple公司的移动操作系统,主要⽤用于iPhone.iPad.iPad Mini.iPod Touch等移动产品. 借助iOS,我们可以开发视频类.美图类.新闻类.⾳乐类.团 ...
- crontab 安装 和一些 简单的命令
crontab命 令常见于Unix和Linux的操作系统之中,用于设置周期性被执行的指令.该命令从标准输入设备读取指令,并将其存放于“crontab”文件中,以供 之后读取和执行.通常,crontab ...
- .net中创建xml文件
//创建空的XML文档 XmlDocument xmldoc = new XmlDocument(); xmldoc.LoadXml("<?xml version='1.0' enco ...
- form的onsubmit事件--表单提交前的验证最佳实现方式
今天遇到了一个问题,页面中include了很多的公共页面(都是没有form的),并且里面好多的地方都是自行提交的(页面中加入一个type=“submit”域,然后js中写入sumbit.click来执 ...
- Spring中@Transactional用法深度分析
引言: 在Spring中@Transactional提供一种控制事务管理的快捷手段,但是很多人都只是@Transactional简单使用,并未深入了解,其各个配置项的使用方法,本文将深入讲解各个配置项 ...
- 推荐一些android开发学习的资料
网址: 1:http://v.youku.com/v_show/id_XMTgwMTQ1MTgw.html 2:http://mars.apkbus.com/ 3:http://wenku.baidu ...
- 哪些函数不能为virtual函数
1> 内联函数 内联函数是在编译时期展开,而虚函数的特性是运行时才动态联编,所以两者矛盾,不能定义内联函数为虚函数. 2> 构造函数 构造函数用来创建一个新的对象,而虚函数的运行是建立在对 ...
- STL学习小结
STL就是Standard Template Library,标准模板库.这可能是一个历史上最令人兴奋的工具的最无聊的术语.从根本上说,STL是一些"容器"的集合,这些" ...
- [译] AlphaGo 的确是一个大事件
[译] AlphaGo 的确是一个大事件 转自:http://www.jianshu.com/p/157a15de47df 字数3797 阅读696 评论0 喜欢4 作者:Michael Nielse ...
- JSBinding + SharpKit / 安装SharpKit以及添加SharpKit工程
本文说明如何往 sln 中添加 SharpKit 工程,以及配置. SharpKit 工程用于将 C# 源代码编译成 JS 代码. QQ群 189738580 1. 安装SharpKit 到 sha ...