Rumah > hujung hadapan web > tutorial js > Dom节点 vs 元素,两者有什么区别?

Dom节点 vs 元素,两者有什么区别?

青灯夜游
Lepaskan: 2021-05-20 10:34:42
ke hadapan
2939 orang telah melayarinya
<p>Dom节点 vs 元素,两者有什么区别?

<p>文档对象模型(DOM)是一个将HTML或XML文档视为树形结构的接口,其中每个节点都是文档的一个对象。DOM还提供了一组方法来查询树、改变结构、样式。

<p>DOM 还使用术语元素(Element)它与节点非常相似。那么,DOM节点和元素之间有什么区别呢?

1. DOM节点

<p>理解节点和元素之间区别的关键是理解节点是什么。

<p>更高的角度来看,DOM文档由节点层次结构组成。 每个节点可以具有父级和/或子级。

<p>看看下面的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>
Salin selepas log masuk
<p>该文档包含以下节点层次结构:

<p>1.png

<p><html>是文档树中的一个节点。它有2个子节点:<head><body>

<p><body>子有3个子节点的节点:注释节点 <!-- Page Body -->,标题<h2>,段落<p><body>节点的父节点是<html>节点。

<p>HTML文档中的标记代表一个节点,有趣的是普通文本也是一个节点。段落节点<p>有1个子节点:文本节点“Thank you for visiting my web page!”

1.2节点类型

<p>我们要如何区分这些不同类型的节点? 答案在于DOM Node接口,尤其是Node.nodeType属性。

<p>Node.nodeType可以具有代表节点类型的以下值之一:

  • Node.ELEMENT_NODE
  • Node.ATTRIBUTE_NODE
  • Node.TEXT_NODE
  • Node.CDATA_SECTION_NODE
  • Node.PROCESSING_INSTRUCTION_NODE
  • Node.COMMENT_NODE
  • Node.DOCUMENT_NODE
  • Node.DOCUMENT_TYPE_NODE
  • Node.DOCUMENT_FRAGMENT_NODE
  • Node.NOTATION_NODE
<p>常量有意义地指示节点类型:例如Node.ELEMENT_NODE代表元素节点,Node.TEXT_NODE代表文本节点,Node.DOCUMENT_NODE文档节点,依此类推。

<p>例如,让我们选择段落节点,然后查看其nodeType属性:

const paragraph = document.querySelector(&#39;p&#39;);

paragraph.nodeType === Node.ELEMENT_NODE; // => true
Salin selepas log masuk
<p>代表整个节点文档树的节点类型为Node.DOCUMENT_NODE

document.nodeType === Node.DOCUMENT_NODE; // => true
Salin selepas log masuk

2. DOM元素

<p>掌握了DOM节点的知识之后,现在该区分DOM节点和元素了。

<p>如果你了解节点术语,那么答案是显而易见的:元素是特定类型的节点 element (Node.ELEMENT_NODE),以及文档、注释、文本等类型。

<p>简而言之,元素是使用HTML文档中的标记编写的节点。 <html><head><title><body><h2><p>都是元素,因为它们由标签表示。

<p>文档类型,注释,文本节点不是元素,因为它们没有使用标签编写:

<p>Node是节点的构造函数,HTMLElement 是 JS DOM 中元素的构造函数。段落既是节点又是元素,它同时是NodeHTMLElement的实例

const paragraph = document.querySelector(&#39;p&#39;);

paragraph instanceof Node;        // => true
paragraph instanceof HTMLElement; // => true
Salin selepas log masuk
<p>简单地说,元素是节点的子类型,就像猫是动物的子类型一样。

3. DOM属性:节点和元素

<p>除了区分节点和元素之外,还需要区分只包含节点或只包含元素的DOM属性。

<p>节点类型的以下属性评估为一个节点或节点集合(NodeList):

node.parentNode; // Node or null

node.firstChild; // Node or null
node.lastChild;  // Node or null

node.childNodes; // NodeList
Salin selepas log masuk
<p>但是,以下属性是元素或元素集合(HTMLCollection):

node.parentElement; // HTMLElement or null

node.children;      // HTMLCollection
Salin selepas log masuk
<p>由于node.childNodes和node.children都返回子级列表,因此为什么要同时具有这两个属性? 好问题!

<p>考虑以下包含某些文本的段落元素:

<p>
  <b>Thank you</b> for visiting my web page!
</p>
Salin selepas log masuk
<p>打开演示,然后查看parapgraph节点的childNodeschildren属性:

const paragraph = document.querySelector(&#39;p&#39;);

paragraph.childNodes; // NodeList:       [HTMLElement, Text]
paragraph.children;   // HTMLCollection: [HTMLElement]
Salin selepas log masuk
<p>paragraph.childNodes集合包含2个节点: <b>Thank you</b>,,以及for visiting my web page!文本节点!

<p>但是,paragraph.children集合仅包含1个项目:<b>Thank you</b>

<p>由于paragraph.children仅包含元素,因此此处未包含文本节点,因为其类型是文本(Node.TEXT_NODE),而不是元素(Node.ELEMENT_NODE)。

<p>同时拥有node.childNodesnode.children,我们可以选择要访问的子级集合:所有子级节点或仅子级是元素。

4.总结

<p>DOM文档是节点的分层集合,每个节点可以具有父级和/或子级。如果了解节点是什么,那么了解DOM节点和元素之间的区别就很容易。

<p>节点有类型,元素类型就是其中之一,元素由HTML文档中的标记表示。

<p>英文原文地址:https://dmitripautin.com/dom-node-element/

<p>作者:Shadeed

<p>来源:dmitripavlutin

<p>更多编程相关知识,请访问:编程教学!!

Atas ialah kandungan terperinci Dom节点 vs 元素,两者有什么区别?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:segmentfault.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan