菜单
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

XML 教程

XML HOME XML 简介 XML 用途 XML 树 XML 语法 XML 元素 XML 属性 XML 命名空间 XML 显示 XML HttpRequest XML 解析器 XML DOM XML XPath XML XSLT XML XQuery XML XLink XML 验证器 XML DTD XML Schema XML 服务器 XML 示例 XML 测验 XML 证书

XML AJAX

AJAX Introduction AJAX XMLHttp AJAX Request AJAX Response AJAX XML File AJAX PHP AJAX ASP AJAX Database AJAX Applications AJAX Examples

XML DOM

DOM Introduction DOM Nodes DOM Accessing DOM Node Info DOM Node List DOM Traversing DOM Navigating DOM Get Values DOM Change Nodes DOM Remove Nodes DOM Replace Nodes DOM Create Nodes DOM Add Nodes DOM Clone Nodes DOM Examples

XPath 教程

XPath Introduction XPath Nodes XPath Syntax XPath Axes XPath Operators XPath Examples

XSLT 教程

XSLT Introduction XSL Languages XSLT Transform XSLT <template> XSLT <value-of> XSLT <for-each> XSLT <sort> XSLT <if> XSLT <choose> XSLT Apply XSLT on the Client XSLT on the Server XSLT Edit XML XSLT Examples

XQuery 教程

XQuery Introduction XQuery Example XQuery FLWOR XQuery HTML XQuery Terms XQuery Syntax XQuery Add XQuery Select XQuery Functions

XML DTD

DTD Introduction DTD Building Blocks DTD Elements DTD Attributes DTD Elements vs Attr DTD Entities DTD Examples

XSD Schema

XSD 简介 XSD 如何使用 XSD <schema> XSD 元素 XSD 属性 XSD 限制 XSD 复杂元素 XSD 空 XSD 仅元素 XSD 仅文本 XSD 混合 XSD 指示符 XSD <any> XSD <anyAttribute> XSD 替换 XSD 示例

XSD Data Types

XSD String XSD Date/Time XSD Numeric XSD Misc XSD Reference

Web Services

XML Services XML WSDL XML SOAP XML RDF XML RSS

参考手册

DOM 节点类型 DOM 节点 DOM NodeList DOM NamedNodeMap DOM Document DOM Element DOM Attribute DOM Text DOM CDATA DOM Comment DOM XMLHttpRequest DOM 解析器 XSLT 元素 XSLT/XPath 函数

XML DOM 节点


根据 XML DOM,XML 文档中的所有内容都是一个节点

  • 整个文档是一个文档节点
  • 每个 XML 元素都是一个元素节点
  • XML 元素中的文本是文本节点
  • 每个属性都是一个属性节点
  • 注释是注释节点

DOM 示例

请看下面的 XML 文件 (books.xml)

<?xml version="1.0" encoding="UTF-8"?>
<bookstore>
  <book category="cooking">
    <title lang="en">Everyday Italian</title>
    <author>Giada De Laurentiis</author>
    <year>2005</year>
    <price>30.00</price>
  </book>
  <book category="children">
    <title lang="en">Harry Potter</title>
    <author>J K. Rowling</author>
    <year>2005</year>
    <price>29.99</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>
  <book category="web" cover="paperback">
    <title lang="en">Learning XML</title>
    <author>Erik T. Ray</author>
    <year>2003</year>
    <price>39.95</price>
  </book>
</bookstore>

上面 XML 中的根节点名为 <bookstore>。

文档中的所有其他节点都包含在 <bookstore> 中。

根节点 <bookstore> 包含 4 个 <book> 节点。

第一个 <book> 节点包含子节点:<title>、<author>、<year> 和 <price>。

子节点各包含一个文本节点,分别为“Everyday Italian”、“Giada De Laurentiis”、“2005”和“30.00”。



文本始终存储在文本节点中

DOM 处理中一个常见的错误是期望元素节点包含文本。

然而,元素节点的文本存储在文本节点中。

在此示例中:<year>2005</year>,元素节点 <year> 包含一个值为“2005”的文本节点。

“2005”不是 <year> 元素的值!


XML DOM 节点树

XML DOM 将 XML 文档视为树形结构。该树形结构称为节点树。

所有节点都可以通过该树访问。它们的内容可以被修改或删除,并且可以创建新的元素。

节点树显示了节点集以及它们之间的连接。树从根节点开始,并分支到树的最底层文本节点

DOM node tree

上图表示 XML 文件 books.xml


节点父级、子级和同级

节点树中的节点彼此之间具有层次关系。

父级、子级和同级等术语用于描述这些关系。父节点有子节点。同一级别的子节点称为同级(兄弟姐妹)。

  • 在节点树中,顶部节点称为根节点
  • 除根节点外,每个节点都只有一个父节点
  • 一个节点可以有任意数量的子节点
  • 叶节点是没有子节点的节点
  • 同级节点是具有相同父节点的节点

下图展示了节点树的一部分以及节点之间的关系

Node tree

由于 XML 数据以树形结构排列,因此可以在不知道树的精确结构和其中包含的数据类型的情况下进行遍历。

您将在本教程的后续章节中学习更多关于遍历节点树的知识。


第一个子节点 - 最后一个子节点

请看下面的 XML 片段

<bookstore>
  <book category="cooking">
    <title lang="en">Everyday Italian</title>
    <author>Giada De Laurentiis</author>
    <year>2005</year>
    <price>30.00</price>
  </book>
</bookstore>

在上面的 XML 中,<title> 元素是 <book> 元素的第一个子节点,<price> 元素是 <book> 元素的最后一个子节点。

此外,<book> 元素是 <title>、<author>、<year> 和 <price> 元素的父节点。


×

联系销售

如果您想将 W3Schools 服务用于教育机构、团队或企业,请发送电子邮件给我们
sales@w3schools.com

报告错误

如果您想报告错误,或想提出建议,请发送电子邮件给我们
help@w3schools.com

W3Schools 经过优化,旨在方便学习和培训。示例可能经过简化,以提高阅读和学习体验。教程、参考资料和示例会不断审查,以避免错误,但我们无法保证所有内容的完全正确性。使用 W3Schools 即表示您已阅读并接受我们的使用条款Cookie 和隐私政策

版权所有 1999-2024 Refsnes Data。保留所有权利。W3Schools 由 W3.CSS 提供支持