当我在两个不同的元素上调用getElementsByClassName时,我很难理解结果中的差异:
考虑以下代码:
let section:HTMLElement = document.getElementById("mainSection");
// This returns NodeListOf<Element>
let blah1 = section.getElementsByClassName("blah");
// This returns HTMLCollectionOf<Element>
let blah2 = document.getElementsByClassName("blah");为什么当我在section上调用方法时,我得到了一个NodeList,而当我在文档上调用它时,我得到了一个HTMLCollection
基于MDN Documentation,它们不应该都返回一个HTMLCollection吗
发布于 2017-06-24 04:39:07
javascript对象只包含有效的document元素,这是标准的保证。
然而,HTML元素(您的selection就是)可以包含其他无效的HTML元素或节点(比如纯文本,它是一个节点,但不能(合法地)存在于Javascript文档中)。
NodeList和HTMLCollection几乎是一样的,但是HTMLCollection使用传统的面向对象语言扩展了NodeList,也就是说,它可以做NodeList能做的一切,但它也有namedItem方法。
https://stackoverflow.com/questions/44729501
复制相似问题