欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

XML轻松学习手册(5)XML实例解析

程序员文章站 2022-06-19 14:22:47
第五章:xml实例解析 提纲: 一:实例效果 二:实例解析   1.定义新标识。  2.建立xml文档。  3.建立相应的html文件。 xml在不同领域有着广泛的应用,比...

第五章:xml实例解析

提纲:

一:实例效果

二:实例解析
  1.定义新标识。
  2.建立xml文档。
  3.建立相应的html文件。

xml在不同领域有着广泛的应用,比如在科技领域的mathml,无线通信应用的wml,在网络图象方面的svg等等,我们这里侧重讨论xml在web上的应用。xml在web上应用主要是利用其强大的数据操作能力。一般用xml配合javascript和asp等服务器端程序,可以实现网络上几乎所有的应用需求。

考虑讲解方便,我们在下面介绍一个简单的实例,不包含服务器端程序。目的在于让您对xml的数据操作能力有一个感性的认识。

好,我们首先[ 点击这里 ]来看实例的效果。(请用ie5.0以上版本浏览器打开)

这是一个简单的cd唱片数据检索功能。你通过点击"上一张","下一张"可以看到单张cd的有关信息。这样的效果我们原来用两种方法可以实现:

1.利用dhtml,将数据隐藏在不同的层中,通过鼠标事件依次显示;

2.利用后台程序(如asp,cgi,php,jsp等),调用服务器端的数据。

但是在这个实例中,我们打开页面原代码可以看到,其中没有用dhtml的div,也没有表单的action,它完全是用xml来实现的。下面我们来分析它的制作过程:

第一步:定义新标识。
根据实际的cd数据,首先新建一个名为<cd>的标识;其次建立它相关的数据标识,分别是:cd名称<title>,演唱者<artist>,出版年代<year>,国家<country>,发行公司<company>和价格<price>;最后还要建立一个名为目录<catalog>的标识。为什么要再建立一个<catalog>标识呢?因为在xml文档中规定,必须且只能有一个根元素(标识),我们有多个cd数据,这些数据是并列的关系,所以需要为这些并列的元素建立一个根元素。
以上元素的定义和关系都完全符合xml标准,不需要特别的dtd文件来定义,所以可以省略dtd定义。如果我们想使用dtd来定义,以上过程可以表示为:

<!element catalog (cd)*>
<!element cd (title,artist,year,country,company,price)>
<!element title (#pcdata)>
<!element artist (#pcdata)>
<!element year (#pcdata)>
<!element country (#pcdata)>
<!element company (#pcdata)>
<!element price (#pcdata)>

这段代码表示:元素catalog包含多个cd子元素,而子元素cd又依次包含title, artist, year, country, company, price 六个子元素,它们的内容都定义为文本(字符,数字,文本)。(注:具体的语法说明可以看上一章关于dtd的介绍)

第二步:建立xml文档。

<?xml version="1.0"?>
<catalog>
<cd>
<title>empire burlesque</title>
<artist>bob dylan</artist>
<country>usa</country>
<company>columbia</company>
<price>10.90</price>
<year>1985</year>
</cd>
<cd>
<title>hide your heart</title>
<artist>bonnie tylor</artist>
<country>uk</country>
<company>cbs records</company>
<price>9.90</price>
<year>1988</year>
</cd>
<cd>
<title>greatest hits</title>
<artist>dolly parton</artist>
<country>usa</country>
<company>rca</company>
<price>9.90</price>
<year>1982</year>
</cd>
<cd>
<title>still got the blues</title>
<artist>gary more</artist>
<country>uk</country>
<company>virgin redords</company>
<price>10.20</price>
<year>1990</year>
</cd>
<cd>
<title>eros</title>
<artist>eros ramazzotti</artist>
<country>eu</country>
<company>bmg</company>
<price>9.90</price>
<year>1997</year>
</cd>
</catalog>

上面代码首先用<?xml version="1.0"?>声明语句表明这是一个xml文档,它的格式遵守xml 1.0标准规范。然后是文档内容,结构树非常清晰:
<catalog>
<cd>
......
</cd>
<cd>
......
</cd>

</catalog>
一共定义了5组数据。我们将上面的代码存为cd.xml文件,以备调用。

第三步:建立相应的html文件。
1.导入xml数据。
我们知道,目前流行的浏览器中,暂时只有微软的ie5.0以上版本浏览器支持xml。ie是通过在html中的object物件来支持插入xml,并通过js的xmldocument.load()方法来导入数据。我们看代码: <object width="0" height="0"
classid="clsid:550dda30-0541-11d2-9ca9-0060b0ec3d39" id="xmldso">
</object>

定义一个object,id名为xmldso。然后在head区用js引入xml数据:

<script for="window" event="onload">
xmldso.xmldocument.load("cd.xml");
</script>

2.捆绑数据。
然后将用<span>标识来将xml数据绑定在表格中。其中id,datasrc,dtatfld都是<span>的属性。代码如下:

<table>
<tr><td>title:</td><td><span id="title" datasrc=#xmldso datafld="title"></span></td></tr>
<tr><td>artist:</td><td><span id="artist" datasrc=#xmldso datafld="artist"></span></td></tr>
<tr><td>year:</td><td><span id="year" datasrc=#xmldso datafld="year"></span></td></tr>
<tr><td>country:</td><td><span id="country" datasrc=#xmldso datafld="country"></span></td></tr>
<tr><td>company:</td><td><span id="company" datasrc=#xmldso datafld="company"></span></td></tr>
<tr><td>price:</td><td><span id="price" datasrc=#xmldso datafld="price"></span></td></tr>
</table>

3.动作操作。
最后,为数据提供浏览按钮:
<input type=button value="上一张cd" onclick="moveprevious()">
<input type=button value="下一张cd" onclick="movenext()">

并利用js来完成两个鼠标点击功能:movenext()和moveprevious()。在head区加入如下代码:

<script language="javascript">
function movenext()
{
if (xmldso.recordset.absoluteposition < xmldso.recordset.recordcount)
{
xmldso.recordset.movenext();
}
}
function moveprevious()
{
if (xmldso.recordset.absoluteposition > 1)
{
xmldso.recordset.moveprevious();
}
}
</script>

好,我们先看html文件的全部原代码:

<html>
<head>

<script for="window" event="onload">
xmldso.xmldocument.load("cd.xml");
</script>

<script language="javascript">
function movenext()
{
if (xmldso.recordset.absoluteposition < xmldso.recordset.recordcount)
{
xmldso.recordset.movenext();
}
}
function moveprevious()
{
if (xmldso.recordset.absoluteposition > 1)
{
xmldso.recordset.moveprevious();
}
}
</script>

<title>cd navigate</title>
</head>

<body>
<p>
<object width="0" height="0"
classid="clsid:550dda30-0541-11d2-9ca9-0060b0ec3d39" id="xmldso">
</object>

<table>
<tr><td>title:</td><td><span id="title" datasrc=#xmldso datafld="title"></span></td></tr>
<tr><td>artist:</td><td><span id="artist" datasrc=#xmldso datafld="artist"></span></td></tr>
<tr><td>year:</td><td><span id="year" datasrc=#xmldso datafld="year"></span></td></tr>
<tr><td>country:</td><td><span id="country" datasrc=#xmldso datafld="country"></span></td></tr>
<tr><td>company:</td><td><span id="company" datasrc=#xmldso datafld="company"></span></td></tr>
<tr><td>price:</td><td><span id="price" datasrc=#xmldso datafld="price"></span></td></tr>
</table>

<p>
<input type=button value="上一张cd" onclick="moveprevious()">
<input type=button value="下一张cd" onclick="movenext()">
</p>

</body>
</html>

将以上代码存为cd.htm文件,于第二步的cd.xml文件放在一起。打开cd.htm文件,你就看见和上面实例一样的效果了。

好,到今天为止,我们已经学习了关于xml的不少知识,我们来总结一下前面五个章节,分别是xml快速入门,xml的概念原理,xml的术语,xml的语法和本章的实例解析。到这里,教程部分就结束了。在写作过程中,阿捷尽最大努力将有关xml概念讲得通俗易懂,尽量把自己的理解告诉给大家,但因为本人学习xml时间也不长,对整个xml的技术把握还不够系统和深入,所以难免有疏漏的地方,请大家指正和谅解,谢谢!