码迷,mamicode.com
首页 > 其他好文 > 详细

XML标准文件结构

时间:2014-08-25 15:11:25      阅读:259      评论:0      收藏:0      [点我收藏+]

标签:中文   version   规格   元素   

        

一个XML文件通常包含文件头和文件体两大部分

1.         文件头

XML文件头由XML声明与DTD文件类型声明组成。其中DTD文件类型声明是可以缺少的,关于DTD声明将在后续的内容中介绍,而XML声明是必须要有的,以使文件符合XML的标准规格。

在前面的Flowers.xml文件中的第一行代码即为XML声明:

<?xml version="1.0" encoding="gb2312"?>

              其中:

“<?”代表一条指令的开始,“?>”代表一条指令的结束;

“xml”代表此文件是XML文件;

“ version="1.0" ”代表此文件用的是XML1.0标准;

“ encoding="gb2312" ” 代表此文件所用的字符集,默认值为Unicode,如果该文件中要用到中文,就必须将此值设定为gb2312。

 

注意:XML声明必须出现在文档的第一行。

 

2.         文件体

文件体中包含的是XML文件的内容,XML元素是XML文件内容的基本单元。从语法讲,一个元素包含一个起始标记、一个结束标记以及标记之间的数据内容。

 

XML元素与HTML元素的格式基本相同,其格式如下:

<标记名称 属性名1="属性值1" 属性名1="属性值1" ……>内容</标记名称>

 

所有的数据内容都必须在某个标记的开始和结束标记内,而每个标记又必须包含在另一个标记的开始与结束标记内,形成嵌套式的分布,只有最外层的标记不必被其他的标记所包含。最外层的是根元素(Root),又称文件(Document)元素,所有的元素都包含在根元素内。

在前面的Flowers.xml文件中,根元素就是<Flowers>,根元素必须而且只能有一个,在该文件有三个<Flower>子元素,这样的元素可以有多个。

4.1.2               XML的基本语法

1.         注释

XML的注释与HTML的注释相同,以“<!--”开始,以“-->”结束。

 

2.         区分大小写

在HTML中是不区分大小写的,而XML区分大小写,包括标记,属性,指令等。

 

3.         标记

XML标记与HTML标记相同,“<”表示一个标记的开始,“>” 表示一个标记的结束。XML中只要有起始标记,就必须有结束标记,而且在使用嵌套结构时,标记之间不能交叉。

在XML中不含任何内容的标记叫做空标记,格式为:<标记名称/>

 

4.         属性

XML属性的使用与HTML属性基本相同,但需要注意的是属性值要加双引号。

 

5.         实体引用

实体引用是指分析文档时会被字符数据取代的元素,实体引用用于XML文档中的特殊字符,否则这些字符会被解释为元素的组成部分。例如,如果要显示“<”,需要使用实体引用“&lt;”否则会被解释为一个标记的起始。

XML中有5个预定义的实体引用,如表 4.1所示。

表 4.1 XML预定义的实体引用

&lt;

&gt;

&quot;

"

&apos;

&amp;

&

 

6.         CDATA

在XML中由一个特殊的标记CDATA,在CDATA中所有文本都不会被XML处理器解释,直接显示在浏览器中,使用方法如下:

<![CDATA[

这里的内容可以直接显示。

]]>

 

7.         处理指令

处理指令使用来给处理XML文件的应用程序提供信息的,处理指令的格式如下:

<?处理指令名称 处理指令信息?>

              例如,XML声明就是一条处理指令:

<?xml version="1.0" encoding="gb2312"?>

其中,“xml”是处理指令名称,version="1.0" encoding="gb2312"是处理指令信息。

4.2         XML与CSS

利用CSS可以用来设定XML文件的显示方式,即在XML文件的头部,XML声明的下面加入下面一条语句:

       <?xml:stylesheet type="text/css" href="css文件的URL"?>

 

下面我们通过例子来介绍如何利用CSS来显示XML文件。首先建立一个css文件,代码如下:

 

flowers.css:一个显示XML文件的CSS样式

       flower{font-size:24px; display:block}

vendor{font-size:36px;color:red}

price{display:block}

 

然后,在flowers.xml文件中使用这个css样式,即在flowers.xml文件中的XML声明下面加入以下语句:

<?xml:stylesheet type="text/css" href="flowers.css"?>

 

完整的程序代码如下:

ex4_3_01.xml:利用CSS 显示XML文件

<?xml version="1.0" encoding="gb2312"?>

<?xml:stylesheet type="text/css" href="Flowers.css"?>

 

<Flowers>

<Flower>

       <Vendor>shop1</Vendor>

       <Name>iris</Name>

       <Price>$4.00</Price>

</Flower>

<Flower>

       <Vendor>shop2</Vendor>

       <Name>iris</Name>

       <Price>$4.30</Price>

</Flower>

<Flower>

       <Vendor>shop3</Vendor>

       <Name>iris</Name>

       <Price>$3.50</Price>

</Flower>

</Flowers>

      

       此例在浏览器中的显示效果如图 4.2所示。

 

利用CSS 显示XML文件

       用CSS来显示XML文件时,不具备任何选择性,也就是说,根元素之下的所有数据都会被全部显示,不能改变原文件的结构和内容的顺序。另外,CSS并不支持中文标记,因为CSS 不是专门为XML开发的样式语言,而下面要介绍到的XSL就可以,XSL是特别为XML设计的,它比CSS更为复杂。

4.3         XSL

在上一节介绍的用CSS显示XML文件,效果不是很理想,实际上,CSS主要是适合HTML文件,对于XML这种数据文件,CSS就不适合了,尤其是对那些需要按照不同的条件将文件内容重新排列显示的情况,而用XSL就可以。

XSL是当前最强大和灵活的样式语言,是特别为应用XML而设计的,它比CSS要复杂的多。但是,目前它还未被很好的支持,也还没有最后完成。

利用XSL来设定XML文件的显示方式,即在XML文件的头部,XML声明的下面加入下面一条语句:

       <?xml:stylesheet type="text/xsl" href="xsl文件的URL"?>

 

下面我们通过例子来介绍如何利用XSL来显示XML文件。首先建立一个xsl文件,代码如下:

flowers.xsl:用来显示XML文件的xsl文件

<?xml version="1.0" encoding="gb2312"?>

<xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">

<xsl:template match = "/">

    <table border="1">

    <tr align="center">

           <th width="100">Vendor</th>

           <th width="100">Flower</th>

           <th width="100">Price</th>

    </tr>

    <xsl:for-each select="//Flowers/Flower">

    <tr align="center">

           <td><xsl:value-of select="Vendor"/></td>

           <td><xsl:value-of select="Name"/></td>

           <td><xsl:value-of select="Price"/></td>

    </tr>

    </xsl:for-each>

    </table>

</xsl:template>

</xsl:stylesheet>

 

我们可以看出:一个XSL文件就如一个空的HTML文件,通过填充一个XML文件产生一个传统的HTML文件。

一个XSL文件首先必须有一个XML声明(即第一行),因为XSL实际上是一种特殊的XML文件。XSL的根元素是xsl:stylesheet,即一个XSL文件必须以<xsl:stylesheet>标记开始,以</xsl:stylesheet>标记结束,xmlns:xsl属性用于设定XSL的命名域。

XSL的根元素通常是由一个或多个样板元素所组成,在此例中只包含单一样板,它是由<xsl:template>标记开始,以<xsl:template>标记结束,使用match属性可以在XML文件中选取符合条件的节点,即设定样板名称,对于最上层样板,match设为“/”,代表整个XML文件的根元素。

然后是从XML文件中取得所需的数据,取得数据最简单的方法是:

<xsl:value-of select="模式"/>

如果要取得多个元素,则要使用xsl:for-each元素,格式如下:

<xsl:for-each select="模式">

…..

</xsl:for-each>

 

 

接下来,我们要在flowers.xml文件中使用这个xsl文件,即在flowers.xml文件中的XML声明下面加入以下语句:

<?xml:stylesheet type="text/xsl" href="flowers.xsl"?>

 

完整的程序代码如下:

ex4_4_01.xml:利用XSL 显示XML文件

<?xml version="1.0" encoding="gb2312"?>

<?xml:stylesheet type="text/xsl" href="flowers.xsl"?>

 

<Flowers>

<Flower>

       <Vendor>shop1</Vendor>

       <Name>iris</Name>

       <Price>$4.00</Price>

</Flower>

<Flower>

       <Vendor>shop2</Vendor>

       <Name>iris</Name>

       <Price>$4.30</Price>

</Flower>

<Flower>

       <Vendor>shop3</Vendor>

       <Name>iris</Name>

       <Price>$3.50</Price>

</Flower>

</Flowers>

 



本文出自 “PHPer” 博客,请务必保留此出处http://webphp.blog.51cto.com/8690270/1544641

XML标准文件结构

标签:中文   version   规格   元素   

原文地址:http://webphp.blog.51cto.com/8690270/1544641

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!