文档对象模型(DOM)是一个将HTML或XML文档视为树形结构的接口,其中每个节点都是文档的一个对象。DOM还提供了一组方法来查询树、改变结构、样式。
DOM 还使用术语元素(Element)它与节点非常相似。那么,DOM节点和元素之间有什么区别呢?
理解节点和元素之间区别的关键是理解节点是什么。
更高的角度来看,DOM文档由节点层次结构组成。 每个节点可以具有父级和/或子级。
看看下面的HTML文档:
<!DOCTYPE html> <html> <head> <title>My Page</title> </head> <body> <!-- Page Body --> <h2>My Page</h2> <p id="content">Thank you for visiting my web page!</p> </body> </html>
该文档包含以下节点层次结构:
100db36a723c770d327fc0aef2ce13b1
是文档树中的一个节点。它有2个子节点:93f0f5c25f18dab9d176bd4f6de5d30e
和6c04bd5ca3fcae76e30b72ad730ca86d
。
6c04bd5ca3fcae76e30b72ad730ca86d
子有3个子节点的节点:注释节点 2555c9f5492bb650995c371a289165c0
,标题c1a436a314ed609750bd7c7d319db4da
,段落e388a4556c0f65e1904146cc1a846bee
。6c04bd5ca3fcae76e30b72ad730ca86d
节点的父节点是100db36a723c770d327fc0aef2ce13b1
节点。
HTML文档中的标记代表一个节点,有趣的是普通文本也是一个节点。段落节点e388a4556c0f65e1904146cc1a846bee
有1个子节点:文本节点“Thank you for visiting my web page!”
。
我们要如何区分这些不同类型的节点? 答案在于DOM Node接口,尤其是Node.nodeType
属性。
Node.nodeType
可以具有代表节点类型的以下值之一:
常量有意义地指示节点类型:例如Node.ELEMENT_NODE
代表元素节点,Node.TEXT_NODE
代表文本节点,Node.DOCUMENT_NODE
文档节点,依此类推。
例如,让我们选择段落节点,然后查看其nodeType
属性:
const paragraph = document.querySelector('p'); paragraph.nodeType === Node.ELEMENT_NODE; // => true
代表整个节点文档树的节点类型为Node.DOCUMENT_NODE
:
document.nodeType === Node.DOCUMENT_NODE; // => true
掌握了DOM节点的知识之后,现在该区分DOM节点和元素了。
如果你了解节点术语,那么答案是显而易见的:元素是特定类型的节点 element (Node.ELEMENT_NODE)
,以及文档、注释、文本等类型。
简而言之,元素是使用HTML文档中的标记编写的节点。 100db36a723c770d327fc0aef2ce13b1
,93f0f5c25f18dab9d176bd4f6de5d30e
,b2386ffb911b14667cb8f0f91ea547a7
,6c04bd5ca3fcae76e30b72ad730ca86d
,c1a436a314ed609750bd7c7d319db4da
,e388a4556c0f65e1904146cc1a846bee
都是元素,因为它们由标签表示。
文档类型,注释,文本节点不是元素,因为它们没有使用标签编写:
Node
是节点的构造函数,HTMLElement
是 JS DOM 中元素的构造函数。段落既是节点又是元素,它同时是Node
和HTMLElement
的实例
const paragraph = document.querySelector('p'); paragraph instanceof Node; // => true paragraph instanceof HTMLElement; // => true
简单地说,元素是节点的子类型,就像猫是动物的子类型一样。
除了区分节点和元素之外,还需要区分只包含节点或只包含元素的DOM属性。
节点类型的以下属性评估为一个节点或节点集合(NodeList
):
node.parentNode; // Node or null node.firstChild; // Node or null node.lastChild; // Node or null node.childNodes; // NodeList
但是,以下属性是元素或元素集合(HTMLCollection
):
node.parentElement; // HTMLElement or null node.children; // HTMLCollection
由于node.childNodes
和node.children都返回子级列表,因此为什么要同时具有这两个属性? 好问题!
考虑以下包含某些文本的段落元素:
<p> <b>Thank you</b> for visiting my web page! </p>
打开演示,然后查看parapgraph节点的childNodes
和children
属性:
const paragraph = document.querySelector('p'); paragraph.childNodes; // NodeList: [HTMLElement, Text] paragraph.children; // HTMLCollection: [HTMLElement]
paragraph.childNodes
集合包含2个节点: a4b561c25d9afb9ac8dc4d70affff419Thank you0d36329ec37a2cc24d42c7229b69747a
,,以及for visiting my web page!
文本节点!
但是,paragraph.children
集合仅包含1个项目:a4b561c25d9afb9ac8dc4d70affff419Thank you0d36329ec37a2cc24d42c7229b69747a
。
由于paragraph.children
仅包含元素,因此此处未包含文本节点,因为其类型是文本(Node.TEXT_NODE
),而不是元素(Node.ELEMENT_NODE
)。
同时拥有node.childNodes
和node.children
,我们可以选择要访问的子级集合:所有子级节点或仅子级是元素。
DOM文档是节点的分层集合,每个节点可以具有父级和/或子级。如果了解节点是什么,那么了解DOM节点和元素之间的区别就很容易。
节点有类型,元素类型就是其中之一,元素由HTML文档中的标记表示。
英文原文地址:https://dmitripautin.com/dom-node-element/
作者:Shadeed
来源:dmitripavlutin
更多编程相关知识,请访问:编程教学!!
以上是Dom节点 vs 元素,两者有什么区别?的详细内容。更多信息请关注PHP中文网其他相关文章!