源码网,源码论坛,源码之家,商业源码,游戏源码下载,discuz插件,棋牌源码下载,精品源码论坛

 找回密码
 立即注册
楼主: ttx9n

[XML/XSLT] XML中的属性学习教程

[复制链接]

7万

主题

861

回帖

32万

积分

论坛元老

Rank: 8Rank: 8

积分
329525
发表于 2016-2-14 10:58:13 | 显示全部楼层 |阅读模式
这篇文章主要介绍了XML中的属性学习教程,包括使用属性将数据存储在子元素中的例子,需要的朋友可以参考下

属性是 XML 元素的一部分。一个元素可以有多个唯一属性。属性提供了 XML 元素的更多信息。更准确地说,它们定义了元素的属性(property)。XML 属性始终是一个_名-值_对。

语法
XML 属性语法如下:

XML/HTML Code复制内容到剪贴板
  1. <element-name attribute1 attribute2 >  
  2. ....content..   
  3. </element-name>  

其中 attribute1 和 attribute2 具有以下形式:

XML/HTML Code复制内容到剪贴板
  1. name = "value"  

value 必须使用双引号(" ")或单引号(' ')包裹。这里 attribute1 和 attribute2 都是唯一的属性标签。

属性被用来给元素添加一个唯一标签,分类标签,添加布尔值属性或者关联一些字符串数据。下面的示例演示了如何使用属性:

XML/HTML Code复制内容到剪贴板
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <!DOCTYPE garden [   
  3.     <!ELEMENT garden (plants)*>  
  4.     <!ELEMENT plants (#PCDATA)>  
  5.     <!ATTLIST plants category CDATA #REQUIRED>  
  6. ]>  
  7. <garden>  
  8. <plants category="flowers" />  
  9. <plants category="shrubs">  
  10. </plants>  
  11. </garden>  

属性被用来区分同名元素。当我们不希望为每种情况都创建一个新元素时。我们可以使用属性添加更多的细节以区分两个或多个类似的元素。

在上面的例子中,我们通过包含 category 属性分类了植物,并且给每个元素分配了不同的值。因此我们就有了两个 plants 类别,一个是 flowers,另一个是 color。这样我们都得到了两个带有不同属性的 plants 元素。

你还可以看到我们在 XML 的开头定义了这个属性。

属性类型
下表列出了属性的类型:

属性类型 描述
StringType 接受字符串值作为值。CDATA 是一个 StringType。CDATA 也是字符数据。这也意味着任何非标记字符都是合法的属性。
TokenizedType

这是一个限制类型。语法中指出的有效性约束会在属性值规范化之后应用。下面是 TokenizedType 属性:

  • ID:用来指定元素是唯一的。
  • IDREF:用来引用一个ID,该ID命名了另一个元素。
  • IDREFS:用来引用一个元素的所有 IDs。
  • ENTITY:指示属性将表示文档中的一个外部实体。
  • ENTITYS:指示属性将表示文档中的一个外部实体。
  • NMTOKEN:类似限制哪些数据可以是属性一部分的CDATA。
  • NMTOKENS:类似限制哪些数据可以是属性一部分的CDATA。
EnumeratedType

在它的声明中包含一个预定义的值列表。在这里,它必须分配一个值。有两种类型的枚举属性:

  • NotationType:它声明元素在 XML 文档的某些地方将被引用为一个 NOTATION 声明。
  • Enumeration:枚举允许我们定义一个特定值列表,属性值必须与之匹配。

元素属性规则
以下是定义属性需要遵循的规则:

同一起始标签或者空元素标签中属性名只能出现一次。
属性必须使用属性属性列表声明(Attribute-List Declaration)定义在文档类型定义(DTD)中。
属性值中不能直接或者间接引用包含外部实体。
属性值中被直接或间接提及的任何实体的替代文本都不能包含小于号(<)。

将数据存储在子元素中
一个案例中使用了日期属性:

XML/HTML Code复制内容到剪贴板
  1. <note date="12/11/2002">  
  2. <to>Tove</to>  
  3. <from>Jani</from>  
  4.   
  5. <heading>Reminder</heading>  
  6. <body>Don't forget me this weekend!</body>  
  7. </note>  

第二个案例中使用了日期元素:

XML/HTML Code复制内容到剪贴板
  1. <note>  
  2. <date>12/11/2002</date>  
  3.   
  4. <to>Tove</to>  
  5. <from>Jani</from>  
  6. <heading>Reminder</heading>  
  7. <body>Don't forget me this weekend!</body>  
  8. </note>  

第三个案例中使用了扩展日期元素(这是我们常用的方法):

XML/HTML Code复制内容到剪贴板
  1. <note>  
  2. <date>  
  3.   <day>12</day>  
  4.   <month>11</month>  
  5.   
  6.   <year>2002</year>  
  7. </date>  
  8. <to>Tove</to>  
  9. <from>Jani</from>  
  10. <heading>Reminder</heading>  
  11.   
  12. <body>Don't forget me this weekend!</body>  
  13. </note>  
回复

使用道具 举报

0

主题

1万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2022-8-8 21:31:59 | 显示全部楼层
谢谢楼主分享
回复 支持 反对

使用道具 举报

2

主题

2万

回帖

99

积分

注册会员

Rank: 2

积分
99
发表于 2022-9-6 23:12:29 | 显示全部楼层
挺不错的东西
回复 支持 反对

使用道具 举报

16

主题

2万

回帖

174

积分

注册会员

Rank: 2

积分
174
发表于 2023-2-22 20:11:33 | 显示全部楼层
呵呵呵呵呵呵
回复 支持 反对

使用道具 举报

0

主题

2万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2023-4-30 11:28:25 | 显示全部楼层
很不错的样子
回复 支持 反对

使用道具 举报

0

主题

2万

回帖

186

积分

注册会员

Rank: 2

积分
186
发表于 2023-11-14 06:53:46 | 显示全部楼层
hi哦回复iOS就看见
回复 支持 反对

使用道具 举报

6

主题

1万

回帖

174

积分

注册会员

Rank: 2

积分
174
发表于 2024-3-26 03:13:43 | 显示全部楼层
逛逛看看瞧瞧
回复 支持 反对

使用道具 举报

0

主题

1万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2024-4-28 14:50:28 | 显示全部楼层
啦啦啦啦啦啦哈哈哈
回复 支持 反对

使用道具 举报

0

主题

1万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2024-6-5 17:08:15 | 显示全部楼层
激动人心,无法言表!
回复 支持 反对

使用道具 举报

14

主题

1万

回帖

75

积分

注册会员

Rank: 2

积分
75
发表于 2024-6-19 18:02:52 | 显示全部楼层
下载来瞧瞧
回复 支持 反对

使用道具 举报

高级模式
B Color Image Link Quote Code Smilies

本版积分规则

手机版|小黑屋|网站地图|源码论坛 ( 海外版 )

GMT+8, 2024-11-23 16:40 , Processed in 0.094017 second(s), 23 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表