XML元素(element)与属性(attribute)

为了简单说清楚什么是元素与属性,拿下面的xml文档作例子。

<bookstore>
<book category="CHILDREN">
  
<title>Harry Potter</title> 
  
<author>J K. Rowling</author> 
  
<year>2005</year> 
  
<price>29.99</price> 
</book>
<book category="WEB">
  
<title>Learning XML</title> 
  
<author>Erik T. Ray</author> 
  
<year>2003</year> 
  
<price>39.95</price> 
</book>
</bookstore>

在上例中,<bookstore> 和 <book> 都拥有元素内容,因为它们包含了其他元素。<author> 只有文本内容,因为它仅包含文本。而只有 <book> 元素拥有属性 (category="CHILDREN")。

 

1. XML 元素

XML 元素必须遵循以下命名规则:

  • 名称可以含字母、数字以及其他的字符
  • 名称不能以数字或者标点符号开始
  • 名称不能以字符 “xml”(或者 XML、Xml)开始
  • 名称不能包含空格

它可使用任何名称,没有保留的字词。元素名称应当比较简短,避免出现像"-",".",":"这些字符。

XML 元素是可扩展的,可以经常在不中断应用程序的情况进行扩展.

 

2. XML 属性

属性通常提供不属于数据组成部分的信息。

XML 属性必须加引号,属性值必须被引号包围,不过单引号和双引号均可使用。比如一个人的性别,person 标签可以这样写:

<person sex="female">

或者这样也可以:

<person sex='female'>

注释:如果属性值本身包含双引号,那么有必要使用单引号包围它,就像这个例子:

<gangster name='George "Shotgun" Ziegler'>

或者可以使用实体引用:

<gangster name="George &quot;Shotgun&quot; Ziegler">

 

3. XML 元素 vs. 属性

请看这些例子:

<person sex="female">
  
<firstname>Anna</firstname>
  
<lastname>Smith</lastname>
</person> 

<person>
  
<sex>female</sex>
  
<firstname>Anna</firstname>
  
<lastname>Smith</lastname>
</person>

在第一个例子中,sex 是一个属性。在第二个例子中,sex 则是一个子元素。两个例子均可提供相同的信息。
没有什么规矩可以告诉我们什么时候该使用属性,而什么时候该使用子元素。根据经验,在 HTML 中,属性用起来很便利,但是在 XML 中,应该尽量避免使用属性。如果信息感觉起来很像数据,那么请使用子元素吧。

 

4.避免 XML 属性?

因使用属性而引起的一些问题:

  • 属性无法包含多个值(子元素可以)
  • 属性无法描述树结构(子元素可以)
  • 属性不易扩展(为未来的变化)
  • 属性难以阅读和维护

请尽量使用元素来描述数据。而仅仅使用属性来提供与数据无关的信息。

不要做这样的蠢事(这不是 XML 应该被使用的方式):

<note day="08" month="08" year="2008"
to
="George" from="John" heading="Reminder" 
body
="Don't forget the meeting!">
</note>

 

5. 针对元数据的 XML 属性

有时候会向元素分配 ID 引用。这些 ID 索引可用于标识 XML 元素,它起作用的方式与 HTML 中 ID 属性是一样的。这个例子向我们演示了这种情况:

<messages>
  
<note id="501">
    
<to>George</to>
    
<from>John</from>
    
<heading>Reminder</heading>
    
<body>Don't forget the meeting!</body>
  
</note>
  
<note id="502">
    
<to>John</to>
    
<from>George</from>
    
<heading>Re: Reminder</heading>
    
<body>I will not</body>
  
</note> 
</messages>


上面的 ID 仅仅是一个标识符,用于标识不同的便签。它并不是便签数据的组成部分。

在此我们极力向您传递的理念是:元数据(有关数据的数据)应当存储为属性,而数据本身应当存储为元素。

posted on 2009-05-18 12:58  炜升  阅读(2196)  评论(0编辑  收藏  举报