返回旧版| 微信建站| 建站之家论坛| 我要建站 | 建站学习 | 加入收藏
XML教程当前位置:首页 > HTML教程 > XML教程 > 正文

XML基础教程(5)XML实例解析

发布时间:2013-09-06 13:28:00   来源:   点击:

 第五章: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文档。

  1. <?xml version="1.0"?> 
  2. <CATALOG> 
  3. <CD> 
  4. <TITLE>Empire Burlesque</TITLE> 
  5. <ARTIST>Bob Dylan</ARTIST> 
  6. <COUNTRY>USA</COUNTRY> 
  7. <COMPANY>Columbia</COMPANY> 
  8. <PRICE>10.90</PRICE> 
  9. <YEAR>1985</YEAR> 
  10. </CD> 
  11. <CD> 
  12. <TITLE>Hide your heart</TITLE> 
  13. <ARTIST>Bonnie Tylor</ARTIST> 
  14. <COUNTRY>UK</COUNTRY> 
  15. <COMPANY>CBS Records</COMPANY> 
  16. <PRICE>9.90</PRICE> 
  17. <YEAR>1988</YEAR> 
  18. </CD> 
  19. <CD> 
  20. <TITLE>Greatest Hits</TITLE> 
  21. <ARTIST>Dolly Parton</ARTIST> 
  22. <COUNTRY>USA</COUNTRY> 
  23. <COMPANY>RCA</COMPANY> 
  24. <PRICE>9.90</PRICE> 
  25. <YEAR>1982</YEAR> 
  26. </CD> 
  27. <CD> 
  28. <TITLE>Still got the blues</TITLE> 
  29. <ARTIST>Gary More</ARTIST> 
  30. <COUNTRY>UK</COUNTRY> 
  31. <COMPANY>Virgin redords</COMPANY> 
  32. <PRICE>10.20</PRICE> 
  33. <YEAR>1990</YEAR> 
  34. </CD> 
  35. <CD> 
  36. <TITLE>Eros</TITLE> 
  37. <ARTIST>Eros Ramazzotti</ARTIST> 
  38. <COUNTRY>EU</COUNTRY> 
  39. <COMPANY>BMG</COMPANY> 
  40. <PRICE>9.90</PRICE> 
  41. <YEAR>1997</YEAR> 
  42. </CD> 
  43. </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>的属性。代码如下:

  1. <table> 
  2. <tr><td>Title:</td><td><SPAN ID="title" DATASRC=#xmldso DATAFLD="TITLE"></SPAN></td></tr> 
  3. <tr><td>Artist:</td><td><SPAN ID="artist" DATASRC=#xmldso DATAFLD="ARTIST"></SPAN></td></tr> 
  4. <tr><td>Year:</td><td><SPAN ID="year" DATASRC=#xmldso DATAFLD="YEAR"></SPAN></td></tr> 
  5. <tr><td>Country:</td><td><SPAN ID="country" DATASRC=#xmldso DATAFLD="COUNTRY"></SPAN></td></tr> 
  6. <tr><td>Company:</td><td><SPAN ID="company" DATASRC=#xmldso DATAFLD="COMPANY"></SPAN></td></tr> 
  7. <tr><td>Price:</td><td><SPAN ID="price" DATASRC=#xmldso DATAFLD="PRICE"></SPAN></td></tr> 
  8. </table> 

3.动作操作。
最后,为数据提供浏览按钮:
<INPUT TYPE=button VALUE="上一张CD" ONCLICK="moveprevious()">
<INPUT TYPE=button VALUE="下一张CD" ONCLICK="movenext()">

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

  1. <script language="Javascript"> 
  2. function movenext() 
  3. if (xmldso.recordset.absoluteposition < xmldso.recordset.recordcount
  4. xmldso.recordset.movenext(); 
  5. function moveprevious() 
  6. if (xmldso.recordset.absoluteposition > 1) 
  7. xmldso.recordset.moveprevious(); 
  8. </script> 

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

  1. <html> 
  2. <head> 
  3.  
  4. <script for="window" event="onload"> 
  5. xmldso.XMLDocument.load("cd.xml"); 
  6. </script> 
  7.  
  8. <script language="JavaScript"> 
  9. function movenext() 
  10. if (xmldso.recordset.absoluteposition < xmldso.recordset.recordcount
  11. xmldso.recordset.movenext(); 
  12. function moveprevious() 
  13. if (xmldso.recordset.absoluteposition > 1) 
  14. xmldso.recordset.moveprevious(); 
  15. </script> 
  16.  
  17. <TITLE>CD Navigate</TITLE> 
  18. </head> 
  19.  
  20. <body> 
  21. <p> 
  22. <object WIDTH="0" HEIGHT="0" 
  23. CLASSID="clsid:550dda30-0541-11d2-9ca9-0060b0ec3d39" ID="xmldso"> 
  24. </object> 
  25.  
  26. <table> 
  27. <tr><td>Title:</td><td><SPAN ID="title" DATASRC=#xmldso DATAFLD="TITLE"></SPAN></td></tr> 
  28. <tr><td>Artist:</td><td><SPAN ID="artist" DATASRC=#xmldso DATAFLD="ARTIST"></SPAN></td></tr> 
  29. <tr><td>Year:</td><td><SPAN ID="year" DATASRC=#xmldso DATAFLD="YEAR"></SPAN></td></tr> 
  30. <tr><td>Country:</td><td><SPAN ID="country" DATASRC=#xmldso DATAFLD="COUNTRY"></SPAN></td></tr> 
  31. <tr><td>Company:</td><td><SPAN ID="company" DATASRC=#xmldso DATAFLD="COMPANY"></SPAN></td></tr> 
  32. <tr><td>Price:</td><td><SPAN ID="price" DATASRC=#xmldso DATAFLD="PRICE"></SPAN></td></tr> 
  33. </table> 
  34.  
  35. <p> 
  36. <INPUT TYPE=button VALUE="上一张CD" ONCLICK="moveprevious()"> 
  37. <INPUT TYPE=button VALUE="下一张CD" ONCLICK="movenext()"> 
  38. </p> 
  39.  
  40. </body> 
  41. </html> 

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

   好,到今天为止,我们已经学习了关于XML的不少知识,我们来总结一下前面五个章节,分别是XML快速入门,XML的概念原理,XML的术语,XML的语法和本章的实例解析。到这里,教程部分就结束了。

版权所有:郑州腾石网络科技有限公司 备案信息:豫ICP备18019117号
站长QQ:2863868475 业务合作咨询:15137100750(同微信)
本站所有投放的广告是有其他网站提供,不代表本站立场,同时网站首页广告位对外出租详情咨询本站站长!同时欢迎广大站长加入个人建站团队
  • 建站客服
  • CMS仿站
  • CMS学习
  • 技术交流群:336572814