+
80
-

HTMLCollection 与 NodeList有啥区别?

HTMLCollection 与 NodeList有啥区别?‘’


网友回复

+
0
-

HTMLCollection 和 NodeList 都是 DOM API 中常用的集合对象,它们的主要区别在于它们所包含的元素和集合属性的不同。

HTMLCollection 对象表示一个 HTML 元素的集合,它是一个有序的、实时的集合。也就是说,当文档中的元素发生改变时,HTMLCollection 对象会自动更新。例如,当您使用 document.forms 获取表单元素时,它返回的就是一个 HTMLCollection 对象。通过document.getElementsByTagName() 可以获取HTMLCollection对象。 NodeList 对象表示一个节点的集合,它也是一个有序的、实时的集合。与 HTMLCollection 不同的是,NodeList 对象可以包含不仅仅是 HTML 元素,还可以包含其他类型的节点,例如文本节点、注释节点等。例如,当您使用  document.querySelectorAll()获取元素时,它返回的就是一个 NodeList 对象。 另外,HTMLCollection 和 NodeList 在集合属性上也有所不同。HTMLCollection 提供了一些特定于 HTML 元素的集合属性,例如 length、namedItem 等。而 NodeList 则提供了一些通用的集合属性,例如 length、item 等。 需要注意的是,虽然 HTMLCollection 和 NodeList 都是类数组对象,它们并不是 JavaScript 数组。因此,它们不具有数组的一些方法和属性,例如 slice、map、forEach 等。
我知道答案,我要回答