菜单
×
   ❮     
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 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 Parser 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 部分结束的 "]]>" 不能包含空格或换行符。


×

联系销售

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

报告错误

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

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

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