XML轻松学习手册(五):XML语法
2023-06-13 09:13:44 时间
第五章: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来定义,以上过程可以表示为:
<!ELEMENTCATALOG(CD)*>
<!ELEMENTCD(Title,Artist,Year,Country,Company,Price)>
<!ELEMENTTitle(#PCDATA)>
<!ELEMENTArtist(#PCDATA)>
<!ELEMENTYear(#PCDATA)>
<!ELEMENTCountry(#PCDATA)>
<!ELEMENTCompany(#PCDATA)>
<!ELEMENTPrice(#PCDATA)>
这段代码表示:元素CATALOG包含多个CD子元素,而子元素CD又依次包含Title,Artist,Year,Country,Company,Price六个子元素,它们的内容都定义为文本(字符,数字,文本)。(注:具体的语法说明可以看上一章关于DTD的介绍) 第二步:建立XML文档。
<?xmlversion="1.0"?>
<CATALOG>
<CD>
<TITLE>EmpireBurlesque</TITLE>
<ARTIST>BobDylan</ARTIST>
<COUNTRY>USA</COUNTRY>
<COMPANY>Columbia</COMPANY>
<PRICE>10.90</PRICE>
<YEAR>1985</YEAR>
</CD>
<CD>
<TITLE>Hideyourheart</TITLE>
<ARTIST>BonnieTylor</ARTIST>
<COUNTRY>UK</COUNTRY>
<COMPANY>CBSRecords</COMPANY>
<PRICE>9.90</PRICE>
<YEAR>1988</YEAR>
</CD>
<CD>
<TITLE>GreatestHits</TITLE>
<ARTIST>DollyParton</ARTIST>
<COUNTRY>USA</COUNTRY>
<COMPANY>RCA</COMPANY>
<PRICE>9.90</PRICE>
<YEAR>1982</YEAR>
</CD>
<CD>
<TITLE>Stillgottheblues</TITLE>
<ARTIST>GaryMore</ARTIST>
<COUNTRY>UK</COUNTRY>
<COMPANY>Virginredords</COMPANY>
<PRICE>10.20</PRICE>
<YEAR>1990</YEAR>
</CD>
<CD>
<TITLE>Eros</TITLE>
<ARTIST>ErosRamazzotti</ARTIST>
<COUNTRY>EU</COUNTRY>
<COMPANY>BMG</COMPANY>
<PRICE>9.90</PRICE>
<YEAR>1997</YEAR>
</CD>
</CATALOG>
上面代码首先用<?xmlversion="1.0"?>声明语句表明这是一个XML文档,它的格式遵守XML1.0标准规范。然后是文档内容,结构树非常清晰:
<CATALOG>
<CD>
......
</CD>
<CD>
......
</CD>
</CATALOG>
一共定义了5组数据。我们将上面的代码存为cd.xml文件,以备调用。 第三步:建立相应的HTML文件。
1.导入XML数据。
我们知道,目前流行的浏览器中,暂时只有微软的IE5.0以上版本浏览器支持XML。IE是通过在HTML中的object物件来支持插入XML,并通过js的XMLDocument.load()方法来导入数据。我们看代码:
<objectWIDTH="0"HEIGHT="0"
CLASSID="clsid:550dda30-0541-11d2-9ca9-0060b0ec3d39"ID="xmldso">
</object>
定义一个object,ID名为xmldso。然后在head区用js引入xml数据:
<scriptfor="window"event="onload">
xmldso.XMLDocument.load("cd.xml");
</script>
2.捆绑数据。
然后将用<SPAN>标识来将XML数据绑定在表格中。其中ID,DATASRC,DTATFLD都是<SPAN>的属性。代码如下:
<table>
<tr><td>Title:</td><td><SPANID="title"DATASRC=#xmldsoDATAFLD="TITLE"></SPAN></td></tr>
<tr><td>Artist:</td><td><SPANID="artist"DATASRC=#xmldsoDATAFLD="ARTIST"></SPAN></td></tr>
<tr><td>Year:</td><td><SPANID="year"DATASRC=#xmldsoDATAFLD="YEAR"></SPAN></td></tr>
<tr><td>Country:</td><td><SPANID="country"DATASRC=#xmldsoDATAFLD="COUNTRY"></SPAN></td></tr>
<tr><td>Company:</td><td><SPANID="company"DATASRC=#xmldsoDATAFLD="COMPANY"></SPAN></td></tr>
<tr><td>Price:</td><td><SPANID="price"DATASRC=#xmldsoDATAFLD="PRICE"></SPAN></td></tr>
</table>
3.动作操作。
最后,为数据提供浏览按钮:
<INPUTTYPE=buttonVALUE="上一张CD"ONCLICK="moveprevious()">
<INPUTTYPE=buttonVALUE="下一张CD"ONCLICK="movenext()">
并利用js来完成两个鼠标点击功能:movenext()和moveprevious()。在head区加入如下代码:
<scriptlanguage="JavaScript">
functionmovenext()
{
if(xmldso.recordset.absoluteposition<xmldso.recordset.recordcount)
{
xmldso.recordset.movenext();
}
}
functionmoveprevious()
{
if(xmldso.recordset.absoluteposition>1)
{
xmldso.recordset.moveprevious();
}
}
</script>
好,我们先看HTML文件的全部原代码:
<html>
<head>
<scriptfor="window"event="onload">
xmldso.XMLDocument.load("cd.xml");
</script>
<scriptlanguage="JavaScript">
functionmovenext()
{
if(xmldso.recordset.absoluteposition<xmldso.recordset.recordcount)
{
xmldso.recordset.movenext();
}
}
functionmoveprevious()
{
if(xmldso.recordset.absoluteposition>1)
{
xmldso.recordset.moveprevious();
}
}
</script>
<TITLE>CDNavigate</TITLE>
</head>
<body>
<p>
<objectWIDTH="0"HEIGHT="0"
CLASSID="clsid:550dda30-0541-11d2-9ca9-0060b0ec3d39"ID="xmldso">
</object>
<table>
<tr><td>Title:</td><td><SPANID="title"DATASRC=#xmldsoDATAFLD="TITLE"></SPAN></td></tr>
<tr><td>Artist:</td><td><SPANID="artist"DATASRC=#xmldsoDATAFLD="ARTIST"></SPAN></td></tr>
<tr><td>Year:</td><td><SPANID="year"DATASRC=#xmldsoDATAFLD="YEAR"></SPAN></td></tr>
<tr><td>Country:</td><td><SPANID="country"DATASRC=#xmldsoDATAFLD="COUNTRY"></SPAN></td></tr>
<tr><td>Company:</td><td><SPANID="company"DATASRC=#xmldsoDATAFLD="COMPANY"></SPAN></td></tr>
<tr><td>Price:</td><td><SPANID="price"DATASRC=#xmldsoDATAFLD="PRICE"></SPAN></td></tr>
</table>
<p>
<INPUTTYPE=buttonVALUE="上一张CD"ONCLICK="moveprevious()">
<INPUTTYPE=buttonVALUE="下一张CD"ONCLICK="movenext()">
</p>
</body>
</html>
将以上代码存为cd.htm文件,于第二步的cd.xml文件放在一起。打开cd.htm文件,你就看见和上面实例一样的效果了。
好,到今天为止,我们已经学习了关于XML的不少知识,我们来总结一下前面五个章节,分别是XML快速入门,XML的概念原理,XML的术语,XML的语法和本章的实例解析。到这里,教程部分就结束了。在写作过程中,阿捷尽最大努力将有关XML概念讲得通俗易懂,尽量把自己的理解告诉给大家,但因为本人学习XML时间也不长,对整个XML的技术把握还不够系统和深入,所以难免有疏漏的地方,请大家指正和谅解,谢谢!
在教程最后,附带一章"XML的相关资源",提供了许多非常好的学习网站和资源连接,推荐您保存下来。请继续浏览:XML的相关资源。
(出处:eNet学院)
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来定义,以上过程可以表示为:
<!ELEMENTCATALOG(CD)*>
<!ELEMENTCD(Title,Artist,Year,Country,Company,Price)>
<!ELEMENTTitle(#PCDATA)>
<!ELEMENTArtist(#PCDATA)>
<!ELEMENTYear(#PCDATA)>
<!ELEMENTCountry(#PCDATA)>
<!ELEMENTCompany(#PCDATA)>
<!ELEMENTPrice(#PCDATA)>
这段代码表示:元素CATALOG包含多个CD子元素,而子元素CD又依次包含Title,Artist,Year,Country,Company,Price六个子元素,它们的内容都定义为文本(字符,数字,文本)。(注:具体的语法说明可以看上一章关于DTD的介绍) 第二步:建立XML文档。
<?xmlversion="1.0"?>
<CATALOG>
<CD>
<TITLE>EmpireBurlesque</TITLE>
<ARTIST>BobDylan</ARTIST>
<COUNTRY>USA</COUNTRY>
<COMPANY>Columbia</COMPANY>
<PRICE>10.90</PRICE>
<YEAR>1985</YEAR>
</CD>
<CD>
<TITLE>Hideyourheart</TITLE>
<ARTIST>BonnieTylor</ARTIST>
<COUNTRY>UK</COUNTRY>
<COMPANY>CBSRecords</COMPANY>
<PRICE>9.90</PRICE>
<YEAR>1988</YEAR>
</CD>
<CD>
<TITLE>GreatestHits</TITLE>
<ARTIST>DollyParton</ARTIST>
<COUNTRY>USA</COUNTRY>
<COMPANY>RCA</COMPANY>
<PRICE>9.90</PRICE>
<YEAR>1982</YEAR>
</CD>
<CD>
<TITLE>Stillgottheblues</TITLE>
<ARTIST>GaryMore</ARTIST>
<COUNTRY>UK</COUNTRY>
<COMPANY>Virginredords</COMPANY>
<PRICE>10.20</PRICE>
<YEAR>1990</YEAR>
</CD>
<CD>
<TITLE>Eros</TITLE>
<ARTIST>ErosRamazzotti</ARTIST>
<COUNTRY>EU</COUNTRY>
<COMPANY>BMG</COMPANY>
<PRICE>9.90</PRICE>
<YEAR>1997</YEAR>
</CD>
</CATALOG>
上面代码首先用<?xmlversion="1.0"?>声明语句表明这是一个XML文档,它的格式遵守XML1.0标准规范。然后是文档内容,结构树非常清晰:
<CATALOG>
<CD>
......
</CD>
<CD>
......
</CD>
</CATALOG>
一共定义了5组数据。我们将上面的代码存为cd.xml文件,以备调用。 第三步:建立相应的HTML文件。
1.导入XML数据。
我们知道,目前流行的浏览器中,暂时只有微软的IE5.0以上版本浏览器支持XML。IE是通过在HTML中的object物件来支持插入XML,并通过js的XMLDocument.load()方法来导入数据。我们看代码:
<objectWIDTH="0"HEIGHT="0"
CLASSID="clsid:550dda30-0541-11d2-9ca9-0060b0ec3d39"ID="xmldso">
</object>
定义一个object,ID名为xmldso。然后在head区用js引入xml数据:
<scriptfor="window"event="onload">
xmldso.XMLDocument.load("cd.xml");
</script>
2.捆绑数据。
然后将用<SPAN>标识来将XML数据绑定在表格中。其中ID,DATASRC,DTATFLD都是<SPAN>的属性。代码如下:
<table>
<tr><td>Title:</td><td><SPANID="title"DATASRC=#xmldsoDATAFLD="TITLE"></SPAN></td></tr>
<tr><td>Artist:</td><td><SPANID="artist"DATASRC=#xmldsoDATAFLD="ARTIST"></SPAN></td></tr>
<tr><td>Year:</td><td><SPANID="year"DATASRC=#xmldsoDATAFLD="YEAR"></SPAN></td></tr>
<tr><td>Country:</td><td><SPANID="country"DATASRC=#xmldsoDATAFLD="COUNTRY"></SPAN></td></tr>
<tr><td>Company:</td><td><SPANID="company"DATASRC=#xmldsoDATAFLD="COMPANY"></SPAN></td></tr>
<tr><td>Price:</td><td><SPANID="price"DATASRC=#xmldsoDATAFLD="PRICE"></SPAN></td></tr>
</table>
3.动作操作。
最后,为数据提供浏览按钮:
<INPUTTYPE=buttonVALUE="上一张CD"ONCLICK="moveprevious()">
<INPUTTYPE=buttonVALUE="下一张CD"ONCLICK="movenext()">
并利用js来完成两个鼠标点击功能:movenext()和moveprevious()。在head区加入如下代码:
<scriptlanguage="JavaScript">
functionmovenext()
{
if(xmldso.recordset.absoluteposition<xmldso.recordset.recordcount)
{
xmldso.recordset.movenext();
}
}
functionmoveprevious()
{
if(xmldso.recordset.absoluteposition>1)
{
xmldso.recordset.moveprevious();
}
}
</script>
好,我们先看HTML文件的全部原代码:
<html>
<head>
<scriptfor="window"event="onload">
xmldso.XMLDocument.load("cd.xml");
</script>
<scriptlanguage="JavaScript">
functionmovenext()
{
if(xmldso.recordset.absoluteposition<xmldso.recordset.recordcount)
{
xmldso.recordset.movenext();
}
}
functionmoveprevious()
{
if(xmldso.recordset.absoluteposition>1)
{
xmldso.recordset.moveprevious();
}
}
</script>
<TITLE>CDNavigate</TITLE>
</head>
<body>
<p>
<objectWIDTH="0"HEIGHT="0"
CLASSID="clsid:550dda30-0541-11d2-9ca9-0060b0ec3d39"ID="xmldso">
</object>
<table>
<tr><td>Title:</td><td><SPANID="title"DATASRC=#xmldsoDATAFLD="TITLE"></SPAN></td></tr>
<tr><td>Artist:</td><td><SPANID="artist"DATASRC=#xmldsoDATAFLD="ARTIST"></SPAN></td></tr>
<tr><td>Year:</td><td><SPANID="year"DATASRC=#xmldsoDATAFLD="YEAR"></SPAN></td></tr>
<tr><td>Country:</td><td><SPANID="country"DATASRC=#xmldsoDATAFLD="COUNTRY"></SPAN></td></tr>
<tr><td>Company:</td><td><SPANID="company"DATASRC=#xmldsoDATAFLD="COMPANY"></SPAN></td></tr>
<tr><td>Price:</td><td><SPANID="price"DATASRC=#xmldsoDATAFLD="PRICE"></SPAN></td></tr>
</table>
<p>
<INPUTTYPE=buttonVALUE="上一张CD"ONCLICK="moveprevious()">
<INPUTTYPE=buttonVALUE="下一张CD"ONCLICK="movenext()">
</p>
</body>
</html>
将以上代码存为cd.htm文件,于第二步的cd.xml文件放在一起。打开cd.htm文件,你就看见和上面实例一样的效果了。
好,到今天为止,我们已经学习了关于XML的不少知识,我们来总结一下前面五个章节,分别是XML快速入门,XML的概念原理,XML的术语,XML的语法和本章的实例解析。到这里,教程部分就结束了。在写作过程中,阿捷尽最大努力将有关XML概念讲得通俗易懂,尽量把自己的理解告诉给大家,但因为本人学习XML时间也不长,对整个XML的技术把握还不够系统和深入,所以难免有疏漏的地方,请大家指正和谅解,谢谢!
在教程最后,附带一章"XML的相关资源",提供了许多非常好的学习网站和资源连接,推荐您保存下来。请继续浏览:XML的相关资源。
(出处:eNet学院)
相关文章
- css基础教程学习
- 推荐系统[八]算法实践总结V2:排序学习框架(特征提取标签获取方式)以及京东推荐算法精排技术实战
- Java基础学习笔记二十 IO流详解编程语言
- Java数据持久层框架 MyBatis之API学习三(XML 映射配置文件)详解编程语言
- Oracle用于生成XML的技术(oracle生成xml)
- Linux执行Class:学习掌握Linux的基本操作(linux执行class)
- MySQL中解析XML文件的方法(mysql解析xml)
- MSSQL中XML数据输出实现简易指南(mssql输出xml)
- Linux轻松打开XML文件(linux打开xml文件)
- 使用互联网资源学习Redis笔记(互联网redis学习笔记)
- MySQL中的XML配置方式详解(mysql xml配置c)
- MySQL与XML的完整解读(mysql xml详解)
- 使用 MySQL 存储和解析 XML 格式的数据(mysql xml格式)
- 深入了解MySQL XML数据库数据存储和管理的细节(mysql xml数据库)
- Oracle中XML数据的读取研究(oracle xml读取)
- 《机器学习》作者Tom Mitchell:人工智能如何向人类大脑学习 | GMIC 2017
- XML轻松学习手册(1)XML快速入门
- JavaScript学习笔记(十四)正则表达式
- JqueryAjax学习实例6向WebService发出请求,返回DataSet(XML)异步调用
- python网络编程学习笔记(八):XML生成与解析(DOM、ElementTree)