XML轻松学习手册(5)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数据,首先新建一个名为

  1<cd>的标识;其次建立它相关的数据标识,分别是:CD名称<title>,演唱者<artist>,出版年代<year>,国家<country>,发行公司<company>和价格<price>;最后还要建立一个名为目录<catalog>的标识。为什么要再建立一个<catalog>标识呢?因为在XML文档中规定,必须且只能有一个根元素(标识),我们有多个CD数据,这些数据是并列的关系,所以需要为这些并列的元素建立一个根元素。   
  2以上元素的定义和关系都完全符合XML标准,不需要特别的DTD文件来定义,所以可以省略DTD定义。如果我们想使用DTD来定义,以上过程可以表示为:   
  3  
  4程序代码:  |  [ 复制代码到剪贴板 ]   
  5---|---  
  6  
  7<!--ELEMENT CATALOG (CD)*-->
  8<!--ELEMENT CD (Title,Artist,Year,Country,Company,Price)-->
  9<!--ELEMENT Title (#PCDATA)-->
 10<!--ELEMENT Artist (#PCDATA)-->
 11<!--ELEMENT Year (#PCDATA)-->
 12<!--ELEMENT Country (#PCDATA)-->
 13<!--ELEMENT Company (#PCDATA)-->
 14<!--ELEMENT Price (#PCDATA)-->
 15
 16  
 17  
 18这段代码表示:元素CATALOG包含多个CD子元素,而子元素CD又依次包含Title, Artist, Year, Country, Company, Price 六个子元素,它们的内容都定义为文本(字符,数字,文本)。(注:具体的语法说明可以看上一章关于DTD的介绍)   
 19  
 20第二步:建立XML文档。   
 21  
 22程序代码:  |  [ 复制代码到剪贴板 ]   
 23---|---  
 24  
 25<?xml version="1.0"?>
 26<catalog>
 27<cd>
 28<title>Empire Burlesque</title>
 29<artist>Bob Dylan</artist>
 30<country>USA</country>
 31<company>Columbia</company>
 32<price>10.90</price>
 33<year>1985</year>
 34</cd>
 35<cd>
 36<title>Hide your heart</title>
 37<artist>Bonnie Tylor</artist>
 38<country>UK</country>
 39<company>CBS Records</company>
 40<price>9.90</price>
 41<year>1988</year>
 42</cd>
 43<cd>
 44<title>Greatest Hits</title>
 45<artist>Dolly Parton</artist>
 46<country>USA</country>
 47<company>RCA</company>
 48<price>9.90</price>
 49<year>1982</year>
 50</cd>
 51<cd>
 52<title>Still got the blues</title>
 53<artist>Gary More</artist>
 54<country>UK</country>
 55<company>Virgin redords</company>
 56<price>10.20</price>
 57<year>1990</year>
 58</cd>
 59<cd>
 60<title>Eros</title>
 61<artist>Eros Ramazzotti</artist>
 62<country>EU</country>
 63<company>BMG</company>
 64<price>9.90</price>
 65<year>1997</year>
 66</cd>
 67</catalog>
 68
 69  
 70  
 71上面代码首先用<?xml version="1.0"?>声明语句表明这是一个XML文档,它的格式遵守XML 1.0标准规范。然后是文档内容,结构树非常清晰:   
 72程序代码:  |  [ 复制代码到剪贴板 ]   
 73---|---  
 74  
 75<catalog>
 76<cd>   
 77......   
 78</cd>
 79<cd>   
 80......   
 81</cd>
 82</catalog>
 83
 84一共定义了5组数据。我们将上面的代码存为cd.xml文件,以备调用。   
 85  
 86  
 87第三步:建立相应的HTML文件。   
 881.导入XML数据。   
 89我们知道,目前流行的浏览器中,暂时只有微软的IE5.0以上版本浏览器支持XML。IE是通过在HTML中的object物件来支持插入XML,并通过js的XMLDocument.load()方法来导入数据。我们看代码:   
 90程序代码:  |  [ 复制代码到剪贴板 ]   
 91---|---  
 92  
 93<object classid="clsid:550dda30-0541-11d2-9ca9-0060b0ec3d39" height="0" id="xmldso" width="0">
 94</object>
 95
 96  
 97  
 98定义一个object,ID名为xmldso。然后在head区用js引入xml数据:   
 99  
100程序代码:  |  [ 复制代码到剪贴板 ]   
101---|---  
102  
103<script event="onload" for="window">   
104xmldso.XMLDocument.load("cd.xml");   
105</script>
106
107  
108  
1092.捆绑数据。   
110然后将用<span>标识来将XML数据绑定在表格中。其中ID,DATASRC,DTATFLD都是<span>的属性。代码如下:   
111  
112程序代码:  |  [ 复制代码到剪贴板 ]   
113---|---  
114  
115<table>
116<tr><td>Title:</td><td><span datafld="TITLE" datasrc="#xmldso" id="title"></span></td></tr>
117<tr><td>Artist:</td><td><span datafld="ARTIST" datasrc="#xmldso" id="artist"></span></td></tr>
118<tr><td>Year:</td><td><span datafld="YEAR" datasrc="#xmldso" id="year"></span></td></tr>
119<tr><td>Country:</td><td><span datafld="COUNTRY" datasrc="#xmldso" id="country"></span></td></tr>
120<tr><td>Company:</td><td><span datafld="COMPANY" datasrc="#xmldso" id="company"></span></td></tr>
121<tr><td>Price:</td><td><span datafld="PRICE" datasrc="#xmldso" id="price"></span></td></tr>
122</table>
123
124  
1253.动作操作。   
126最后,为数据提供浏览按钮:   
127程序代码:  |  [ 复制代码到剪贴板 ]   
128---|---  
129  
130<input onclick="moveprevious()" type="button" value="上一张CD"/>
131<input onclick="movenext()" type="button" value="下一张CD"/>
132
133  
134  
135并利用js来完成两个鼠标点击功能:movenext()和moveprevious()。在head区加入如下代码:   
136  
137程序代码:  |  [ 复制代码到剪贴板 ]   
138---|---  
139  
140<script language="JavaScript">   
141function movenext()   
142{   
143if (xmldso.recordset.absoluteposition < xmldso.recordset.recordcount)   
144{   
145xmldso.recordset.movenext();   
146}   
147}   
148function moveprevious()   
149{   
150if (xmldso.recordset.absoluteposition > 1)   
151{   
152xmldso.recordset.moveprevious();   
153}   
154}   
155</script>
156
157  
158好,我们先看HTML文件的全部原代码:   
159  
160程序代码:  |  [ 复制代码到剪贴板 ]   
161---|---  
162  
163<html>
164<head>
165<script event="onload" for="window">   
166xmldso.XMLDocument.load("cd.xml");   
167</script>
168<script language="JavaScript">   
169function movenext()   
170{   
171if (xmldso.recordset.absoluteposition < xmldso.recordset.recordcount)   
172{   
173xmldso.recordset.movenext();   
174}   
175}   
176function moveprevious()   
177{   
178if (xmldso.recordset.absoluteposition > 1)   
179{   
180xmldso.recordset.moveprevious();   
181}   
182}   
183</script>
184<title>CD Navigate</title>
185</head>
186<body>
187<p>
188<object classid="clsid:550dda30-0541-11d2-9ca9-0060b0ec3d39" height="0" id="xmldso" width="0">
189</object>
190<table>
191<tr><td>Title:</td><td><span datafld="TITLE" datasrc="#xmldso" id="title"></span></td></tr>
192<tr><td>Artist:</td><td><span datafld="ARTIST" datasrc="#xmldso" id="artist"></span></td></tr>
193<tr><td>Year:</td><td><span datafld="YEAR" datasrc="#xmldso" id="year"></span></td></tr>
194<tr><td>Country:</td><td><span datafld="COUNTRY" datasrc="#xmldso" id="country"></span></td></tr>
195<tr><td>Company:</td><td><span datafld="COMPANY" datasrc="#xmldso" id="company"></span></td></tr>
196<tr><td>Price:</td><td><span datafld="PRICE" datasrc="#xmldso" id="price"></span></td></tr>
197</table>
198<p>
199<input onclick="moveprevious()" type="button" value="上一张CD"/>
200<input onclick="movenext()" type="button" value="下一张CD"/>
201</p>
202</p></body>
203</html>
204
205  
206将以上代码存为cd.htm文件,于第二步的cd.xml文件放在一起。打开cd.htm文件,你就看见和上面实例一样的效果了。   
207  
208好,到今天为止,我们已经学习了关于XML的不少知识,我们来总结一下前面五个章节,分别是XML快速入门,XML的概念原理,XML的术语,XML的语法和本章的实例解析。到这里,教程部分就结束了。在写作过程中,阿捷尽最大努力将有关XML概念讲得通俗易懂,尽量把自己的理解告诉给大家,但因为本人学习XML时间也不长,对整个XML的技术把握还不够系统和深入,所以难免有疏漏的地方,请大家指正和谅解,谢谢!</span></span></catalog></catalog></price></company></country></year></artist></title></cd>
Published At
Categories with Web编程
Tagged with
comments powered by Disqus