<?xml version="1.0"?>
<books>
<book>
<author>Carson</author>
<price format="dollar">31.95</price>
<pubdate>05/01/2001</pubdate>
</book>
<pubinfo>
<publisher>MSPress</publisher>
<state>WA</state>
</pubinfo>
</books>
下图显示将此 XML 数据读入 DOM 结构中时如何构造内存。
XML 文档结构
在 XML 文档结构中,此图中的每个圆圈表示一个节点(称为 XmlNode 对象)。
XmlNode 对象是 DOM 树中的基本对象。
XmlDocument 类(扩展 XmlNode)支持用于对整个文档执行操作(例如,将文档加载到内存中或将 XML 保存到文件中)的方法。 此外,XmlDocument 提供了查看和处理整个 XML 文档中的节点的方法。
XmlNode 和 XmlDocument 都具有性能和可用性增强,并通过方法和属性执行下列操作:
Node 对象具有一组方法和属性以及基本的和定义完善的特性。 其中的某些特性包括:
节点有单个父节点,父节点是与节点相邻的上一级节点。 唯一没有父级的节点是文档根,因为它是顶级节点,包含了文档本身和文档片段。
大多数节点可以有多个子节点,子节点是与节点相邻的下一级节点。 以下是可以有子节点的节点类型列表。
文档
DocumentFragment
EntityReference
元素
特性
XmlDeclaration、Notation、Entity、CDATASection、Text、Comment、ProcessingInstruction 和 DocumentType 节点没有子节点。
处于同一级别、在关系图中由 book 和 pubinfo 节点表示的节点是同级。
DOM 的一个特性是处理属性的方式。 属性是不属于父子关系和同级关系的节点。 属性被视为元素节点的属性,由名称和值对组成。 例如,如果存在由与元素 format="dollar 关联的 price" 组成的 XML 数据,则单词 format 是名称,format 属性的值是 dollar。 为检索 format="dollar"price 节点的 属性,可以在游标位于 元素节点时调用 priceGetAttribute 方法。 有关更多信息,请参见访问 DOM 中的属性。
将 XML 读入内存时会创建节点。 然而,并非所有节点都是同一类型。 XML 中的元素具有不同于处理指令的规则和语法。 因此,在读取各种数据时,将为每个节点分配一种节点类型。 此节点类型确定节点的特性和功能。
有关在内存中生成的节点类型的更多信息,请参见 XML 节点类型。 有关在节点树中创建的对象的更多信息,请参见将对象层次结构映射到 XML 数据。
Microsoft 扩展了万维网联合会 (W3C) DOM 级别 1 和级别 2 中可用的 API,使 XML 文档的使用更容易。 在完全支持 W3C 标准的同时,附加的类、方法和属性增加了使用 W3C XML DOM 无法完成的功能。 新类使您能够访问关系数据,为您提供与 ADO.NET 数据同步、同时将数据作为 XML 公开的方法。 有关更多信息,请参见使 DataSet 与 XmlDataDocument 同步。
在将 XML 数据读入内存,以更改其结构、添加或移除节点或者与在元素包含的文本中一样修改节点所保存的数据时,DOM 最有用。 不过,在其他方案中,还有其他比 DOM 更快的类。 要对 XML 进行快速非缓存只进流访问,请使用 XmlReader 和 XmlWriter。 如果需要用游标模型和 XPath 进行随机访问,请使用 XPathNavigator 类。