node.nextSibling和ChildNode.nextElementSibling有什么区别?

时间:2014-06-15 04:29:45

标签: javascript dom nodes

<div id="div-01">Here is div-01</div> <div id="div-02">Here is div-02</div>

Aren他们是一回事吗?

两者都返回紧随其后的节点。我读过很多文章,但在我看来是同样的事情,但是不知道在哪里使用其他文章?

1 个答案:

答案 0 :(得分:48)

nextElementSibling始终返回一个元素。 nextSibling可以返回任何类型的节点。它们与您的示例相同,但在其他情况下则不同,例如:

<p><span id="span-01">Here is span-01</span>
Some text at the top level
<span id="span-02">Here is span-02</span></p>

在这种情况下,document.getElementById('span-01').nextElementSiblingspan-02,但document.getElementById('span-01').nextSibling是包含“顶级某些文字”的文字节点(或者,如评论中@Manngo所指出的那样) ,将该文本与上面的元素分开的空格 - 似乎有些浏览器将元素和非空白节点之间的空格分成不同的节点,而其他浏览器则将它与文本的其余部分组合在一起。