XML DOM完全参考手册(一)DOM与节点
XML 文档对象模型定义访问和操作XML文档的标准方法。 DOM 将 XML 文档作为一个树形结构,而树叶被定义为节点。 XML DOM 简介
XML DOM 定义了访问和处理 XML 文档的标准方法。 XML DOM 是 XML Document Object Model 的缩写,即 XML 文档对象模型。
什么是 DOM?DOM 是 W3C(万维网联盟) 的推荐标准。 DOM 定义了访问诸如 XML 和 XHTML 文档的标准。 “W3C 文档对象模型(DOM)是一个使程序和脚本有能力动态地访问和更新文档的内容、结构以及样式的平台和语言中立的接口。” W3C DOM 被分为 3 个不同的部分/级别(parts / levels):
DOM 定义了所有文档元素的对象和属性,以及访问它们的方法(接口)。 您可以在我们的W3C 教程中获得更多有关 W3C DOM 规范/级别的信息。 XML DOM 是:
XML DOM 定义了所有 XML 元素的对象和属性,以及访问它们的方法(接口)。 换句话说: XML DOM 是用于获取、更改、添加或删除 XML 元素的标准。 XML DOM 节点节点根据 DOM,XML 文档中的每个成分都是一个节点。 DOM 是这样规定的:
DOM 实例请看下面的 XML 文件 (books.xml): <?xml version="1.0" encoding="ISO-8859-1"?> <bookstore> <book category="children"> <title lang="en">Harry Potter</title> <author>J K. Rowling</author> <year>2005</year> <price>29.99</price> </book> <book category="cooking"> <title lang="en">Everyday Italian</title> <author>Giada De Laurentiis</author> <year>2005</year> <price>30.00</price> </book> <book category="web"> <title lang="en">Learning XML</title> <author>Erik T. Ray</author> <year>2003</year> <price>39.95</price> </book> <book category="web"> <title lang="en">XQuery Kick Start</title> <author>James McGovern</author> <author>Per Bothner</author> <author>Kurt Cagle</author> <author>James Linn</author> <author>Vaidyanathan Nagarajan</author> <year>2003</year> <price>49.99</price> </book> </bookstore> 在上面的 XML 中,根节点是 <bookstore>。文档中的所有其他节点都被包含在 <bookstore> 中。 根节点 <bookstore> 有四个 <book> 节点。 第一个 <book> 节点有四个节点:<title>,<author>,<year> 以及 <price>,其中每个节点都包含一个文本节点,"Harry Potter","J K. Rowling","2005" 以及 "29.99"。
文本总是存储在文本节点中在 DOM 处理中一个普遍的错误是,认为元素节点包含文本。 不过,元素节点的文本是存储在文本节点中的。 在这个例子中:<year>2005</year>,元素节点 <year>,拥有一个值为 "2005" 的文本节点。 "2005"不是<year> 元素的值! XML DOM 节点树XML DOM 把 XML DOM 文档视为一棵节点树 (node-tree)。 树中的所有节点彼此之间都有关系。 XML DOM 节点树XML DOM 把 XML 文档视为一种树结构。这种树结构被称为节点树。 可通过这棵树访问所有节点。可以修改或删除它们的内容,也可以创建新的元素。 这颗节点树展示了节点的集合,以及它们之间的联系。这棵树从根节点开始,然后在树的最低层级向文本节点长出枝条:
父、子和同级节点 节点树中的节点彼此之间都有等级关系。 父、子和同级节点用于描述这种关系。父节点拥有子节点,位于相同层级上的子节点称为同级节点(兄弟或姐妹)。
下面的图片展示出节点树的一个部分,以及节点间的关系: 因为 XML 数据是按照树的形式进行构造的,所以可以在不了解树的确切结构且不了解其中包含的数据类型的情况下,对其进行遍历 注释:父节点:Parent Node,子节点:Children Node,同级节点:Sibling Node。 转载自W3C官网(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |