最近有很多读者朋友和朋友交朋友dom sub有疑问。有网友整理了相关内容,希望能回答你的疑惑。dom sub是什么意思?这个网站已经为你找到了问题的答案,希望对你有所帮助。
这篇文章已经通过了原作者 Shadeed 授权翻译。
DOM 还使用术语元素(Element)它与节点非常相似。那么,DOM节点和元素有什么区别?
1. 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>
该文件包含以下节点层次结构:
<html>是文档树的节点。</p> </body></html>
该文件包含以下节点层次结构:
<html>它是文档树中的一个节点。它有两个子节点:<head>和<body>。
<body>子节点有三个子节点:注释节点 <!– Page Body –>,标题<h2>,段落<p>。<body>节点的父节点是<html>节点。
- HTML文档中的标记代表一个节点,有趣的是普通文本也是一个节点。段落节点<p>有一个子节点:文本节点Thank you for visiting my web page!”。
- 1.2节点类型
- Node.ELEMENT_NODE
- Node.ATTRIBUTE_NODE
- Node.TEXT_NODE
- Node.CDATA_SECTION_NODE
- Node.PROCESSING_INSTRUCTION_NODE
如何区分这些不同类型的节点?答案在于DOM Node特别是接口Node.nodeType属性。
Node.nodeType具有代表节点类型的以下值之一:
Node.COMMENT_NODE
Node.DOCUMENT_NODE
Node.DOCUMENT_TYPE_NODE
Node.DOCUMENT_FRAGMENT_NODE
Node.NOTATION_NODE
常量有意义地指示节点类型:例如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
2. DOM元素
掌握了DOM节点知识后,现在该区分DOM节点和元素。如果你知道节点术语,答案很明显:元素是特定类型的节点 element (Node.ELEMENT_NODE),以及文档、注释、文本等类型。
如果你知道节点术语,答案是显而易见的是特定类型的节点 element (Node.ELEMENT_NODE),以及文档、注释、文本等类型。
简而言之,使用元素HTML编写文档标记的节点。<html>,<head>,<title>,<body>,<h2>,<p>它们都是由标签表示的元素。文档类型,注释,文本节点不是元素,因为它们不使用标签写作:
Node是节点的结构函数,HTMLElement 是 JS DOM 中元素的构造函数。段落既是节点又是元素,它同时是Node和HTMLElement的实例
const paragraph = document.querySelector('p');paragraph instanceof Node; // => trueparagraph instanceof HTMLElement; // => true
简单地说,元素是节点的子类型,就像猫是动物的子类型一样。
3. DOM属性:节点和元素
除了区分节点和元素外,还需要区分只包含节点或只包含元素DOM属性。
节点类型的以下属性被评估为节点或节点集合(NodeList):
node.parentNode; // Node or nullnode.firstChild; // Node or nullnode.lastChild; // Node or nullnode.childNodes; // NodeList
但是,以下属性是元素或元素的集合(HTMLCollection):
node.parentElement; // HTMLElement or nullnode.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集合包括两个节点:<b>Thank you</b>,,以及for visiting my web page!文本节点!文本节点!
但是,paragraph.children集合只包括一个项目:<b>Thank you</b>。
由于paragraph.children只包含元素,所以这里没有文本节点,因为它的类型是文本(Node.TEXT_NODE),而不是元素(Node.ELEMENT_NODE)。
同时拥有node.childNodes和node.children,我们可以选择要访问的子级集合:所有子级节点或子级是元素。
4.总结
DOM文档是节点的分层集合,每个节点都可以有父级和/或子级。假如知道节点是什么,那么就知道了DOM很容易区分节点和元素。节点有类型,元素类型就是其中之一HTML文件中的标记表示。完~ 我是小智,我要去洗碗,下次见!作者:Shadeed 译者:前端小智 来源:dmitripavlutin原文:https://dmitripautin.com/dom-node-element/
主题测试文章,只做测试使用。发布者:艾迪号,转转请注明出处:https://www.cqaedi.cn/baike/39456.html