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 Apply 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 NamedNodeMap DOM 文档 DOM 元素 DOM 属性 DOM 文本 DOM CDATA DOM 注释 DOM XMLHttpRequest DOM 解析器 XSLT 元素 XSLT/XPath 函数

XML DOM 教程


什么是 DOM?

DOM 定义了访问和操作文档的标准

"W3C 文档对象模型 (DOM) 是一种与平台和语言无关的接口,它允许程序和脚本动态地访问和更新文档的内容、结构和样式。"

HTML DOM 定义了访问和操作 HTML 文档的标准方法。它将 HTML 文档呈现为树形结构。

XML DOM 定义了访问和操作 XML 文档的标准方法。它将 XML 文档呈现为树形结构。

了解 DOM 是任何使用 HTML 或 XML 的人员都必须掌握的。


HTML DOM

所有 HTML 元素都可以通过 HTML DOM 访问。

此示例更改了 id 为 "demo" 的 HTML 元素的值

示例

<h1 id="demo">这是一个标题</h1>

<script>
document.getElementById("demo").innerHTML = "Hello World!";
</script>
亲自尝试 »

此示例更改了 HTML 文档中的第一个 <h1> 元素的值

示例

<h1>这是一个标题</h1>

<h1>这是一个标题</h1>

<script>
document.getElementsByTagName("h1")[0].innerHTML = "Hello World!";
</script>
亲自尝试 »

注意: 即使 HTML 文档中只有一个 <h1> 元素,您仍然必须指定数组索引 [0],因为 getElementsByTagName() 方法始终返回一个数组。

您可以在我们的 JavaScript 教程 中了解更多有关 HTML DOM 的内容。



XML DOM

所有 XML 元素都可以通过 XML DOM 访问。

XML DOM 是

  • XML 的标准对象模型
  • XML 的标准编程接口
  • 与平台和语言无关
  • W3C 标准

换句话说:XML DOM 是如何获取、更改、添加或删除 XML 元素的标准。


获取 XML 元素的值

此代码检索 XML 文档中第一个 <title> 元素的文本值

示例

txt = xmlDoc.getElementsByTagName("title")[0].childNodes[0].nodeValue;

加载 XML 文件

以下示例中使用的 XML 文件是 books.xml

此示例将 "books.xml" 读取到 xmlDoc 中,并检索 books.xml 中第一个 <title> 元素的文本值

示例

<!DOCTYPE html>
<html>
<body>

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

<script>
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
    if (this.readyState == 4 && this.status == 200) {
    myFunction(this);
    }
};
xhttp.open("GET", "books.xml", true);
xhttp.send();

function myFunction(xml) {
    var xmlDoc = xml.responseXML;
    document.getElementById("demo").innerHTML =
    xmlDoc.getElementsByTagName("title")[0].childNodes[0].nodeValue;
}
</script>

</body>
</html>
亲自尝试 »

示例说明

  • xmlDoc - 解析器创建的 XML DOM 对象。
  • getElementsByTagName("title")[0] - 获取第一个 <title> 元素
  • childNodes[0] - <title> 元素的第一个子节点(文本节点)
  • nodeValue - 节点的值(文本本身)

加载 XML 字符串

此示例将文本字符串加载到 XML DOM 对象中,并使用 JavaScript 从中提取信息

示例

<html>
<body>

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

<script>
var text, parser, xmlDoc;

text = "<bookstore><book>" +
"<title>Everyday Italian</title>" +
"<author>Giada De Laurentiis</author>" +
"<year>2005</year>" +
"</book></bookstore>";

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

document.getElementById("demo").innerHTML =
xmlDoc.getElementsByTagName("title")[0].childNodes[0].nodeValue;
</script>

</body>
</html>
亲自尝试 »

编程接口

DOM 将 XML 建模为一组节点对象。可以使用 JavaScript 或其他编程语言访问这些节点。在本教程中,我们使用 JavaScript。

DOM 的编程接口由一组标准属性和方法定义。

属性通常称为某物是什么(例如,nodename 是 "book")。

方法通常称为某物所做的(例如,删除 "book")。


XML DOM 属性

以下是一些典型的 DOM 属性

  • x.nodeName - x 的名称
  • x.nodeValue - x 的值
  • x.parentNode - x 的父节点
  • x.childNodes - x 的子节点
  • x.attributes - x 的属性节点

注意: 以上列表中,x 是一个节点对象。


XML DOM 方法

  • x.getElementsByTagName(name) - 获取所有具有指定标签名称的元素
  • x.appendChild(node) - 向 x 插入一个子节点
  • x.removeChild(node) - 从 x 删除一个子节点

注意: 以上列表中,x 是一个节点对象。


×

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.