XML属性
属性(Attribute)提供关于元素的额外(附加)信息。
属性通常提供不属于数据组成部分的信息。在下面的例子中,文件类型与数据无关,但是对需要处理这个元素的软件来说却很重要:
<filetype="gif">computer.gif</file>
XML属性必须加引号
属性值必须被引号包围,不过单引号和双引号均可使用。
注释:如果属性值本身包含双引号,那么有必要使用单引号包围它,就像这个例子:
<gangstername='George"Shotgun"Ziegler'>
或者可以使用实体引用:
<gangstername="George"Shotgun"Ziegler">
XML元素vs.属性
请看这些例子:
<personsex="female">
<firstname>Anna</firstname>
<lastname>Smith</lastname>
</person>
<person>
<sex>female</sex>
</person>
在第一个例子中,sex是一个属性。在第二个例子中,sex则是一个子元素。两个例子均可提供相同的信息。
没有什么规矩可以告诉我们什么时候该使用属性,而什么时候该使用子元素。我的经验是在HTML中,属性用起来很便利,但是在XML中,您应该尽量避免使用属性。如果信息感觉起来很像数据,那么请使用子元素吧。
我最喜欢的方式
下面的三个XML文档包含完全相同的信息:
第一个例子中使用了date属性:
<notedate="08/08/2008">
<to>George</to>
<from>John</from>
<heading>Reminder</heading>
<body>Don'tforgetthemeeting!</body>
</note>
第二个例子中使用了date元素:
<note>
<date>08/08/2008</date>
</note>
第三个例子中使用了扩展的date元素(这是我的最爱):
<date>
<day>08</day>
<month>08</month>
<year>2008</year>
</date>
</note>
避免XML属性?
因使用属性而引起的一些问题:
·属性无法包含多重的值(元素可以)
·属性无法描述树结构(元素可以)
·属性不易扩展(为未来的变化)
·属性难以阅读和维护
请尽量使用元素来描述数据。而仅仅使用属性来提供与数据无关的信息。
不要做这样的蠢事(这不是XML应该被使用的方式):
<noteday="08"month="08"year="2008"
to="George"from="John"heading="Reminder"
body="Don'tforgetthemeeting!">
针对元数据的XML属性
有时候会向元素分配ID引用。这些ID索引可用于标识XML元素,它起作用的方式与HTML中ID属性是一样的。这个例子向我们演示了这种情况:
<messages>
id="501"id="502"<to>John</to>
<from>George</from>
<heading>Re:Reminder</heading>
<body>Iwillnot</body>
</messages>
上面的ID仅仅是一个标识符,用于标识不同的便签。它并不是标签数据的组成部分。
在此我们极力向您传递的理念是:元数据(有关数据的数据)应当存储为属性,而数据本身应当存储为元素。
XML验证
拥有正确语法的XML被称为“形式良好”的XML。
通过DTD验证的XML是“合法”的XML。
形式良好的XML文档
“形式良好”或“结构良好”的XML文档拥有正确的语法。
“形式良好”(WellFormed)的XML文档会遵守前几章介绍过的XML语法规则:
·XML文档必须有根元素
·XML标签对大小写敏感
·XML元素必须被正确的嵌套
·XML属性必须加引号
验证XML文档
合法的XML文档是“形式良好”的XML文档,同样遵守文档类型定义(DTD)的语法规则:
<?xmlversion="1.0"encoding="ISO-8859-1"?>
<!DOCTYPEnoteSYSTEM"Note.dtd">
</note>
在上例中,DOCTYPE声明是对外部DTD文件的引用。下面的段落展示了这个文件的内容。
XMLDTD
DTD的作用是定义XML文档的结构。它使用一系列合法的元素来定义文档结构:
<!DOCTYPEnote[
<!ELEMENTnote(to,from,heading,body)>
<!ELEMENTto(#PCDATA)>
<!ELEMENTfrom(#PCDATA)>
<!ELEMENTheading(#PCDATA)>
<!ELEMENTbody(#PCDATA)>
]>
XMLSchema
W3C支持一种基于XML的DTD代替者,它名为XMLSchema:
<xs:elementname="note">
<xs:complexType>
<xs:sequence>
<xs:elementname="to"type="xs:string"/>
<xs:elementname="from"type="xs:string"/>
<xs:elementname="heading"type="xs:string"/>
<xs:elementname="body"type="xs:string"/>
</xs:sequence>
</xs:complexType>
</xs:element>
XML验证器
XML错误会终止您的程序
XML文档中的错误会终止你的XML程序。
W3C的XML规范声明:如果XML文档存在错误,那么程序就不应当继续处理这个文档。理由是,XML软件应当轻巧,快速,具有良好的兼容性。
对您的XML进行语法检查
根据DTD来验证XML
<?xmlversion="1.0"?>
<!DOCTYPEnote[
<!ELEMENTto(#PCDATA)>
<!ELEMENTfrom(#PCDATA)>
<!ELEMENTheading(#PCDATA)>
<!ELEMENTbody(#PCDATA)>
]>
<note>
<to>George</to>
<from>John</from>
<heading>Reminder</heading>
<body>Don'tforgetthemeeting!</body>
</note>
注释:只有在InternetExplorer中,可以根据DTD来验证XML。Firefox,Mozilla,Netscape以及Opera做不到这一点。
XML浏览器支持
几乎所有的主流浏览器均支持XML和XSLT。
查看XML文件
在所有现代浏览器中,均能够查看原始的XML文件。
打开XML文件-XML文档将显示为代码颜色化的根以及子元素。通过点击元素左侧的加号或减号,可以展开或收起元素的结构。如需查看不带有+和-符号的源代码,请从浏览器菜单中选择“查看源代码”。
注释:在Netscape,Opera以及Safari中,仅仅会显示元素文本!要查看原始的XML,请右击页面,然后选择“查看源代码”。
为什么XML会这样显示?
XML文档不会携带有关如何显示数据的信息。
在没有任何有关如何显示数据的信息的情况下,大多数的浏览器都会仅仅把XML文档显示为源代码。
可以使用CSS、XSL、JavaScript以及XML数据岛等来格式化XML。
使用CSS格式化XML不是常用的方法,更不能代表XML文档样式化的未来。W3C推荐使用XSLT。
使用XSLT显示XML(首选)
使用XSLT显示XML
XSLT是首选的XML样式表语言。
XSLT(eXtensibleStylesheetLanguageTransformations)远比CSS更加完善。
使用XSLT的方法之一是在浏览器显示XML文件之前,先把它转换为HTML。
在服务器上通过XSLT转换XML
XSLT转换由浏览器完成的,浏览器读取的是XML文件。
在使用XSLT来转换XML时,不同的浏览器可能会产生不同结果。为了减少这种问题,可以在服务器上进行XSLT转换。
请注意,不论转换由服务器还是由浏览器进行,输出结果完成相同。
待续。。。