XML 学习总结(2)

前端之家收集整理的这篇文章主要介绍了XML 学习总结(2)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

XML属性

XML元素可以在开始标签中包含属性,类似HTML

属性(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元素,它起作用的方式与HTMLID属性是一样的。这个例子向我们演示了这种情况:

<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文档是形式良好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支持一种基于XMLDTD代替者,它名为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程序。

W3CXML规范声明:如果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来验证XMLFirefox,Mozilla,Netscape以及Opera做不到这一点。

XML浏览器支持

几乎所有的主流浏览器均支持XMLXSLT

查看XML文件

在所有现代浏览器中,均能够查看原始的XML文件

不要指望XML文件会直接显示HTML页面

打开XML文件-XML文档将显示代码颜色化的根以及子元素。通过点击元素左侧的加号或减号,可以展开或收起元素的结构。如需查看不带有+-符号的源代码,请从浏览器菜单中选择查看源代码

注释:Netscape,Opera以及Safari中,仅仅会显示元素文本!要查看原始的XML,请右击页面,然后选择查看源代码

为什么XML会这样显示

XML文档不会携带有关如何显示数据的信息。

在没有任何有关如何显示数据的信息的情况下,大多数的浏览器都会仅仅把XML文档显示为源代码

可以使用CSSXSLJavaScript以及XML数据岛等来格式化XML

使用CSS格式化XML不是常用的方法,更不能代表XML文档样式化的未来。W3C推荐使用XSLT

使用XSLT显示XML(首选)

通过使用XSLT,您可以向XML文档添加显示信息。

使用XSLT显示XML

XSLT是首选的XML样式表语言。

XSLT(eXtensibleStylesheetLanguageTransformations)远比CSS更加完善。

使用XSLT方法之一是在浏览器显示XML文件之前,先把它转换为HTML

在服务器上通过XSLT转换XML

XSLT转换由浏览器完成的,浏览器读取的是XML文件

在使用XSLT来转换XML时,不同的浏览器可能会产生不同结果。为了减少这种问题,可以在服务器上进行XSLT转换。

请注意,不论转换由服务器还是由浏览器进行,输出结果完成相同。

待续。。。

猜你在找的XML相关文章