美文网首页开发者联盟http
Element和Node的区别你造吗?

Element和Node的区别你造吗?

作者: Pursue | 来源:发表于2016-09-21 14:26 被阅读1135次

    1.写在前面

    我们经常使用document.getElementById去获取DOM中的元素,也会使用childNodes来获取子节点。那么Element和Node的区别是什么?而什么又是HTMLCollection,HTMLElement,和NodeList呢?

    一个简单的页面:

    <html>
      <body>
        <h1>China</h1>
        <!-- My comment ...  -->
        <p>China is a popular country with...</p>
        <div>
          <button>See details</button>
        </div>
      </body>
    </html>
    
    

    body里的直系子元素一共有三个:h,p,div。我们可以用document.body.childNodes查看, 结果如下:

    问题来了:

    • 1.这么会有这么多的#text?
    • 2.注释算节点?

    在回答上面两个问题之前,就有必要理解下什么是Node了。

    2.Node vs Elemet

    以下摘自MDN:

    A Node is an interface from which a number of DOM types inherit, and allows these various types to be treated (or tested) similarly.

    The following interfaces all inherit from Node its methods and properties: Document, Element, CharacterData (which Text, Comment, and CDATASection inherit), ProcessingInstruction, DocumentFragment, DocumentType, Notation, Entity, EntityReference.

    简单的说就是Node是一个基类,DOM中的ElementTextComment都继承于它。
    换句话说,ElementTextComment是三种特殊的Node,它们分别叫做ELEMENT_NODE,
    TEXT_NODECOMMENT_NODE

    所以我们平时使用的html上的元素,即Element是类型为ELEMENT_NODENode

    利用nodeType可以查看所有类型,如下图:

    到这里,我想我们就可以解释上面两个问题了。

    实际上Node表示的是DOM树的结构,在html中,节点与节点之间是可以插入文本的,这个插入的空隙就是TEXT_NODE,即:

    <body>
        we can put text here 1...
        <h1>China</h1>
        we can put text here 2...
        <!-- My comment ...  -->
        we can put text here 3...
        <p>China is a popular country with...</p>
        we can put text here 4...
        <div>
          <button>See details</button>
        </div>
        we can put text here 5 ...
    </body>
    

    这下就顺理成章了,body的直系元素(3)+ COMMENT_NODE(1) + TEXT_NODE(5) = 9

    3.NodeList vs HTMLCollection

    我们用childNodes找到了NodeList,但我们操作DOM时往往不想操作Node(我只想操作元素Element),那么如何获取ElementList呢?

    其实我们经常使用的getElementsByXXX返回的就是一个ElementList,只不过它的真实名字是ElementCollection

    就像NodeListNode的集合一样,ElementCollection也是Element的集合。但需要特别注意的是:

    NodeList和ElementCollcetion都不是真正的数组

    如果document.getElementsByTagName('a') instanceof Array,那么必然是false

    4.写在最后

    DOM(Document Object Model)简称文档对象模型,它是html和xml是文档编程的接口,它将文档解析为树结构,这个树的根部就是document,而document的第一个子节点(childeNodes[0])就是html,这才有了后面的一系列html元素。

    最后附一张DOM图,此刻再看这张图是不是觉得回味无穷咧。

    参考资料:

    1.Node vs Element

    2.DOM

    3.Node

    4.NodeList

    相关文章

      网友评论

      • 清水芦苇:请问如果Element 是 Node的基类 为什么 `Element instanceof Node`返回false呢

        Pursue:@饥人谷_叶世清 Element并不是实例啊,试试document.getElementById('xxx) instanceof Node

      本文标题:Element和Node的区别你造吗?

      本文链接:https://www.haomeiwen.com/subject/bmjaettx.html