菜单
×
   ❮     
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 教程


什么是 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 = "你好,世界!";
</script>
自己动手试一试 »

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

示例

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

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

<script>
document.getElementsByTagName("h1")[0].innerHTML = "你好,世界!";
</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 是一个节点对象。


×

联系销售

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

报告错误

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

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

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