通过 HTML DOM,您可以使用节点关系来导航节点树。
根据 W3C HTML DOM 标准,HTML 文档中的所有内容都是一个节点:
使用 HTML DOM,节点树中的所有节点都可以通过 JavaScript 访问。
可以创建新节点,并且可以修改或删除所有节点。
节点树中的节点相互之间具有层次关系。
术语“父母”、“孩子”和“兄弟姐妹”用于描述这种关系。
<html>
<head>
<title>DOM Tutorial</title>
</head>
<body>
<h1>DOM Lesson one</h1>
<p>Hello world!</p>
</body>
</html>
从上面的 HTML 你可以读到:
<html>
是根节点<html>
没有父母<html>
是的父级<head>
和<body>
<head>
是的第一个孩子<html>
<body>
是最后一个孩子<html>
和:
<head>
有一个孩子:<title>
<title>
有一个子节点(文本节点):"DOM Tutorial"<body>
有两个孩子:<h1>
和<p>
<h1>
有一个孩子:"DOM Lesson one"<p>
有一个孩子:"Hello world!"<h1>
和<p>
是兄弟姐妹您可以使用以下节点属性通过 JavaScript 在节点之间导航:
parentNode
childNodes[nodenumber]
firstChild
lastChild
nextSibling
previousSibling
DOM 处理中的一个常见错误是期望元素节点包含文本。
<title id="demo">DOM Tutorial</title>
元素节点<title>
(在上面的例子中)确实不是包含文本。
它包含一个文本节点值为"DOM Tutorial"。
文本节点的值可以通过节点的innerHTML
属性:
myTitle = document.getElementById("demo").innerHTML;
访问innerHTML属性与访问nodeValue
第一个孩子的:
myTitle = document.getElementById("demo").firstChild.nodeValue;
访问第一个孩子也可以这样完成:
myTitle = document.getElementById("demo").childNodes[0].nodeValue;
以下所有 (3) 个示例都会检索<h1>
元素并将其复制到<p>
元素:
<html>
<body>
<h1 id="id01">My First Page</h1>
<p id="id02"></p>
<script>
document.getElementById("id02").innerHTML = document.getElementById("id01").innerHTML;
</script>
</body>
</html>
亲自试一试 »
<html>
<body>
<h1 id="id01">My First Page</h1>
<p id="id02"></p>
<script>
document.getElementById("id02").innerHTML = document.getElementById("id01").firstChild.nodeValue;
</script>
</body>
</html>
亲自试一试 »
<html>
<body>
<h1 id="id01">My First Page</h1>
<p id="id02">Hello!</p>
<script>
document.getElementById("id02").innerHTML = document.getElementById("id01").childNodes[0].nodeValue;
</script>
</body>
</html>
亲自试一试 »
在本教程中,我们使用innerHTML 属性来检索HTML 元素的内容。
然而,学习上述其他方法对于理解树结构和 DOM 导航很有用。
有两个特殊属性允许访问完整文档:
document.body
- 文档正文document.documentElement
- 完整文件
<html>
<body>
<h2>JavaScript HTMLDOM</h2>
<p>Displaying document.body</p>
<p id="demo"></p>
<script>
document.getElementById("demo").innerHTML = document.body.innerHTML;
</script>
</body>
</html>
亲自试一试 »
<html>
<body>
<h2>JavaScript HTMLDOM</h2>
<p>Displaying document.documentElement</p>
<p id="demo"></p>
<script>
document.getElementById("demo").innerHTML = document.documentElement.innerHTML;
</script>
</body>
</html>
亲自试一试 »
这个nodeName
属性指定节点的名称。
<h1 id="id01">My First Page</h1>
<p id="id02"></p>
<script>
document.getElementById("id02").innerHTML = document.getElementById("id01").nodeName;
</script>
亲自试一试 »
笔记:nodeName
始终包含 HTML 元素的大写标签名称。
这个nodeValue
属性指定节点的值。
null
这个nodeType
属性是只读的。它返回节点的类型。
<h1 id="id01">My First Page</h1>
<p id="id02"></p>
<script>
document.getElementById("id02").innerHTML = document.getElementById("id01").nodeType;
</script>
亲自试一试 »
最重要的 nodeType 属性是:
Node | Type | Example |
---|---|---|
ELEMENT_NODE | 1 | <h1 class="heading">91xjr</h1> |
ATTRIBUTE_NODE | 2 | class = "heading" (deprecated) |
TEXT_NODE | 3 | 91xjr |
COMMENT_NODE | 8 | <!-- This is a comment --> |
DOCUMENT_NODE | 9 | The HTML document itself (the parent of <html>) |
DOCUMENT_TYPE_NODE | 10 | <!Doctype html> |
类型 2 在 HTML DOM 中已被弃用(但可以使用)。它在 XML DOM 中并未被弃用。
截取页面反馈部分,让我们更快修复内容!也可以直接跳过填写反馈内容!