Menu
×
   ❮     
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 主页 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 架构 XML 服务器 XML 示例 XML 测验 XML 证书

XML AJAX

AJAX 简介 AJAX XMLHttp AJAX 请求 AJAX 响应 AJAX XML 文件 AJAX PHP AJAX ASP AJAX 数据库 AJAX 应用 AJAX 示例

XML DOM

DOM 简介 DOM 节点 DOM 访问 DOM 节点信息 DOM 节点列表 DOM 遍历 DOM 导航 DOM 获取值 DOM 更改节点 DOM 删除节点 DOM 替换节点 DOM 创建节点 DOM 添加节点 DOM 克隆节点 DOM 示例

XPath 教程

XPath 简介 XPath 节点 XPath 语法 XPath 轴 XPath 运算符 XPath 示例

XSLT 教程

XSLT 简介 XSL 语言 XSLT 转换 XSLT <template> XSLT <value-of> XSLT <for-each> XSLT <sort> XSLT <if> XSLT <choose> XSLT 应用 客户端上的 XSLT 服务器上的 XSLT XSLT 编辑 XML XSLT 示例

XQuery 教程

XQuery 简介 XQuery 示例 XQuery FLWOR XQuery HTML XQuery 术语 XQuery 语法 XQuery 添加 XQuery 选择 XQuery 函数

XML DTD

DTD 简介 DTD 构建块 DTD 元素 DTD 属性 DTD 元素与属性 DTD 实体 DTD 示例

XSD 架构

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

XSD 数据类型

XSD 字符串 XSD 日期/时间 XSD 数字 XSD 其他 XSD 引用

Web 服务

XML 服务 XML WSDL XML SOAP XML RDF XML RSS

参考文献

DOM 节点类型 DOM 节点 DOM 节点列表 DOM 命名节点映射 DOM 文档 DOM 元素 DOM 属性 DOM 文本 DOM CDATA DOM 注释 DOM XMLHttpRequest DOM 解析器 XSLT 元素 XSLT/XPath 函数

XML DOM 节点列表


getElementsByTagName() 方法和 childNodes 属性返回节点列表。


DOM 节点列表

使用 childNodes 或 getElementsByTagName() 等属性或方法时,将返回一个节点列表对象。

节点列表对象表示节点列表,顺序与 XML 中的顺序相同。

节点列表中的节点通过从 0 开始的索引号访问。

下图表示 books.xml 中 <title> 元素的节点列表。

DOM node list

假设 "books.xml" 已加载到变量 xmlDoc 中。

此代码段返回 "books.xml" 中 title 元素的节点列表

x = xmlDoc.getElementsByTagName("title");

在执行上述语句后,x 是一个节点列表对象。

以下代码段从节点列表 (x) 中返回第一个 <title> 元素的文本。

示例

var txt = x[0].childNodes[0].nodeValue;
亲自试一试 »

在执行上述语句后,txt = "Everyday Italian"。



节点列表长度

节点列表对象会保持最新状态。如果删除或添加了元素,列表将自动更新。

节点列表的 length 属性是列表中节点的数量。

此代码段返回 "books.xml" 中 <title> 元素的数量

x = xmlDoc.getElementsByTagName('title').length;

在执行上述语句后,x 的值为 4。

节点列表的长度可用于循环遍历列表中的所有元素。

此代码段使用 length 属性循环遍历 <title> 元素列表

示例

x = xmlDoc.getElementsByTagName('title');
xLen = x.length;

for (i = 0; i <xLen; i++) {
    txt += x[i].childNodes[0].nodeValue) + " ";
}

输出

Everyday Italian
Harry Potter
XQuery Kick Start
Learning XML
亲自试一试 »

示例解释

  1. 假设 books.xml 已加载到 xmlDoc 中
  2. 设置 x 变量以保存所有 title 元素的节点列表
  3. 从 <title> 元素中收集文本节点值

DOM 属性列表(命名节点映射)

元素节点的 attributes 属性返回一个属性节点列表。

这称为命名节点映射,类似于节点列表,但方法和属性略有不同。

属性列表会保持最新状态。如果删除或添加了属性,列表将自动更新。

此代码段从 "books.xml" 中第一个 <book> 元素中返回属性节点列表

x = xmlDoc.getElementsByTagName('book')[0].attributes;

在执行上述代码后,x.length 是属性数量,x.getNamedItem() 可用于返回属性节点。

此代码段获取 "category" 属性的值和书籍的属性数量

示例

x = xmlDoc.getElementsByTagName("book")[0].attributes;

txt = x.getNamedItem("category").nodeValue + " " + x.length;

输出

cooking 1
亲自试一试 »

示例解释

  1. 假设 books.xml 已加载到 xmlDoc 中
  2. 设置 x 变量以保存第一个 <book> 元素的所有属性列表
  3. 获取 "category" 属性的值和属性列表的长度

×

Contact Sales

If you want to use W3Schools services as an educational institution, team or enterprise, send us an e-mail:
[email protected]

Report Error

If you want to report an error, or if you want to make a suggestion, send us an e-mail:
[email protected]

W3Schools is optimized for learning and training. Examples might be simplified to improve reading and learning. Tutorials, references, and examples are constantly reviewed to avoid errors, but we cannot warrant full correctness of all content. While using W3Schools, you agree to have read and accepted our terms of use, cookie and privacy policy.

Copyright 1999-2024 by Refsnes Data. All Rights Reserved. W3Schools is Powered by W3.CSS.