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 遍历节点树


遍历是指循环或遍历节点树。


遍历节点树

通常您想要循环遍历 XML 文档,例如:当您想要提取每个元素的值时。

这被称为“遍历节点树”。

下面的示例循环遍历 <book> 的所有子节点,并显示其名称和值。

示例

<!DOCTYPE html>
<html>
<body>

<p id="demo"></p>

<script>
var x, i ,xmlDoc;
var txt = "";
var text = "<book>" +
"<title>Everyday Italian</title>" +
"<author>Giada De Laurentiis</author>" +
"<year>2005</year>" +
"</book>";

parser = new DOMParser();
xmlDoc = parser.parseFromString(text,"text/xml");

// documentElement 始终表示根节点
x = xmlDoc.documentElement.childNodes;
for (i = 0; i < x.length ;i++) {
    txt += x[i].nodeName + ": " + x[i].childNodes[0].nodeValue + "<br>";
}
document.getElementById("demo").innerHTML = txt;
</script>

</body>
</html>

输出

title: Everyday Italian
author: Giada De Laurentiis
year: 2005
尝试一下 »

示例说明

  1. 将 XML 字符串加载到 xmlDoc 中
  2. 获取根元素的子节点
  3. 对于每个子节点,输出节点名称和文本节点的节点值


浏览器在 DOM 解析中的差异

所有现代浏览器都支持 W3C DOM 规范。

但是,浏览器之间存在一些差异。一个重要的区别是

  • 它们处理空白和换行符的方式

DOM - 空白和换行符

XML 经常在节点之间包含换行符或空白字符。这在文档由简单的编辑器(如记事本)编辑时很常见。

以下示例(由记事本编辑)在每行之间包含 CR/LF(换行符),并在每个子节点前面包含两个空格

<book>
  <title>Everyday Italian</title>
  <author>Giada De Laurentiis</author>
  <year>2005</year>
  <price>30.00</price>
</book>

Internet Explorer 9 及更早版本不将空空白或换行符视为文本节点,而其他浏览器则会。

以下示例将输出根元素(books.xml)的子节点数量。IE9 及更早版本将输出 4 个子节点,而 IE10 及更高版本以及其他浏览器将输出 9 个子节点

示例

function myFunction(xml) {
var xmlDoc = xml.responseXML;
    x = xmlDoc.documentElement.childNodes;
    document.getElementById("demo").innerHTML =
    "子节点数量: " + x.length;
}
尝试一下 »

PCDATA - 解析的字符数据

XML 解析器通常解析 XML 文档中的所有文本。

当 XML 元素被解析时,XML 标记之间的文本也会被解析

<message>此文本也会被解析</message>

解析器执行此操作是因为 XML 元素可以包含其他元素,如本示例中,<name> 元素包含两个其他元素 (first 和 last)

<name><first>Bill</first><last>Gates</last></name>

解析器会将其分解成以下子元素

<name>
  <first>Bill</first>
  <last>Gates</last>
</name>

解析的字符数据 (PCDATA) 是一个用于描述将被 XML 解析器解析的文本数据的术语。


CDATA - (未解析的)字符数据

CDATA 术语用于描述不应被 XML 解析器解析的文本数据。

在 XML 元素中,"<" 和 "&" 等字符是非法的。

"<" 将会产生错误,因为解析器将其解释为新元素的开始。

"&" 将会产生错误,因为解析器将其解释为字符实体的开始。

某些文本,如 JavaScript 代码,包含大量的 "<" 或 "&" 字符。为了避免错误,脚本代码可以定义为 CDATA。

解析器会忽略 CDATA 部分中的所有内容。

CDATA 部分以“<![CDATA[”开头,以“]]>”结尾

<script>
<![CDATA[
function matchwo(a,b) {
    if (a < b && a < 0) {
        return 1;
    } else {
        return 0;
    }
}
]]>
</script>

在上面的示例中,CDATA 部分内的所有内容都会被解析器忽略。

关于 CDATA 部分的注意事项

CDATA 部分不能包含字符串“]]>”。不允许嵌套 CDATA 部分。

标记 CDATA 部分结束的“]]>”不能包含空格或换行符。


×

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.