面试官:childNodes 和 children 有什么区别?

简介: 前言childNodes 和 children 算是一个细节问题,在当下框架火热的环境中,几乎很少有人会去直接操作 DOM 节点了。但是如果你比较深入的去学习框架之后,会发现它们的底层原理还是逃脱不了 DOM 的操作,所以说,学习这些关于 DOM 的细节问题还是很重要的,面试官也常常会以这些细节来判断一个人的知识是否掌握到位!

1.Node 和 Element


想要学习这两个属性,我们必须要先知道 Node 和 Element 的区别。


在 JS 操作 DOM 的时候,我们有时候会操作 Node 节点,有时候也会才做 Element,这两者的区别有些人傻傻分不清,其实它们两个的区别很简单。


  • Node:

在 DOM 树中,所有的节点都是 Node,包括 Element,也就是说 Node 包含了 HTML 元素标签、text、以及注释等等内容,它是所有 DOM 的基类。


  • Element:

在 DOM 树中,Element 是所有 HTML 元素的基类,也就是说,Element 只包含 HTML 元素标签。

综上两点可以得出:Node 和 Element 两者是包含关系,Node 包含 Element。从而衍生出了两个集合:NodeList 和 HTMLCollection。NodeList 是 Node 的集合,HTMLCollection 是 Element 的集合。


2.childNodes理解


先来看下官网的解释:

Node.childNodes 返回包含指定节点的子节点的集合,该集合为即时更新的集合。


官网说的也比较通俗易懂,childNodes 属性返回的是 DOM 节点的子集合,它属于 NodeList 集合。


如下图所示:33.png


总结:

childNodes会返回所有节点,包括HTML、Text、注释等等内容。


3.children理解


同样先来看下官网解释:

Element.children 是一个只读属性,返回 一个Node的子elements ,是一个动态更新的 HTMLCollection 。


通过官网的解释可以得出:childre属于HTMLCollection集合,它返回的是节点的子elements,通俗的说,children返回的是HTML元素标签。


如下图所示:

34.png

总结:

children只返回元素节点。


4.代码演示

4.1 childNodes

我们任意编写一些HTML代码,然后通过JS获取。

代码如下:

<body>
  <div id="box1">
    <p>小猪课堂</p>
    <span>小猪课堂</span>
    <b>小猪课堂</b>
    <em>小猪课堂</em>
    <!-- 我是注释 -->
  </div>
</body>
<script>
  const box1 = document.getElementById("box1");
  console.info("-----childNodes-----");
  console.info(box1.childNodes);
</script>


输出结果:

35.png


我们会发现输出的节点长度为11,其中多了很多的文本节点,和我们编写的代码产生了冲突,问题就在于childNodes会返回所有节点,包括注释、标签、换行文本等等。

我们把HTML放到一行在执行一遍,代码如下:

<body>
  <div id="box1"><p>小猪课堂</p><span>小猪课堂</span><b>小猪课堂</b><em>小猪课堂</em><!-- 我是注释 --></div>
</body>


输出结果:35.png

这个时候输出结果就和我们的理想结果一样了,输出中包含了节点和注释。


通过上面的代码实例可以看出,如果我们使用childNodes来进行获取子节点,那么换行也会被统计进去,这不是我们想要的结果。为了解决这个问题,我们可以通过nodeType这个属性来判断该节点是什么类型,它的取值有3个:


  • 1:元素节点
  • 2:属性节点
  • 3:文本节点


代码如下:

<body>
  <div id="box1">
    <p>小猪课堂</p>
    <span>小猪课堂</span>
    <b>小猪课堂</b>
    <em>小猪课堂</em>
    <!-- 我是注释 -->
  </div>
</body>
<script>
  const box1 = document.getElementById("box1");
  console.info("-----childNodes-----");
  console.info(box1.childNodes);
  let NodeList = box1.childNodes
  for (let i = 0; i < NodeList.length; i++) {
    if (NodeList[i].nodeType === 1) {
      console.info("元素节点", NodeList[i])
    } else if (NodeList[i].nodeType === 2) {
      console.info("属性节点", NodeList[i])
    } else {
      console.info("文本节点", NodeList[i])
    }
  }
</script>


输出结果:

36.png

4.2 children


我们通过children的方式来看看能获取到哪些元素。

代码如下:

<body>
  <div id="box1">
    <p>小猪课堂</p>
    <span>小猪课堂</span>
    <b>小猪课堂</b>
    <em>小猪课堂</em>
    <!-- 我是注释 -->
  </div>
</body>
<script>
  const box1 = document.getElementById("box1");
  console.info("-----children-----");
  console.info(box1.children);
</script>


输出结果:37.png

此时输出的就只有HTML元素节点了,长度也正是我们的标签元素的个数。


总结


两个属性的区别到这里应该就很清楚了,它们有着各自的有点和缺点,需要根据不同的场景下使用不同的属性,总结如下两点:

  • childNodes属于NodeList集合,它会返回所有的子节点,包括文本、标签、注释等等。
  • children数据HTMLCollection集合,它会返回所有HTML元素节点。
  • childNodes包含children。


如果觉得文章不够详细,可以观看B站视频:小猪课堂



相关文章
|
4月前
|
Java
【Java集合类面试二十八】、说一说TreeSet和HashSet的区别
HashSet基于哈希表实现,无序且可以有一个null元素;TreeSet基于红黑树实现,支持排序,不允许null元素。
|
4月前
|
Java
【Java集合类面试二十三】、List和Set有什么区别?
List和Set的主要区别在于List是一个有序且允许元素重复的集合,而Set是一个无序且元素不重复的集合。
|
4月前
|
存储 Java 索引
【Java集合类面试二十四】、ArrayList和LinkedList有什么区别?
ArrayList基于动态数组实现,支持快速随机访问;LinkedList基于双向链表实现,插入和删除操作更高效,但占用更多内存。
|
28天前
|
Java 程序员
Java社招面试题:& 和 && 的区别,HR的套路险些让我翻车!
小米,29岁程序员,分享了一次面试经历,详细解析了Java中&和&&的区别及应用场景,展示了扎实的基础知识和良好的应变能力,最终成功获得Offer。
67 14
|
3月前
|
Android开发 Kotlin
Android经典面试题之Kotlin的==和===有什么区别?
本文介绍了 Kotlin 中 `==` 和 `===` 操作符的区别:`==` 用于比较值是否相等,而 `===` 用于检查对象身份。对于基本类型,两者行为相似;对于对象引用,`==` 比较值相等性,`===` 检查引用是否指向同一实例。此外,还列举了其他常用比较操作符及其应用场景。
196 93
|
27天前
|
Java 关系型数据库 数据库
京东面试:聊聊Spring事务?Spring事务的10种失效场景?加入型传播和嵌套型传播有什么区别?
45岁老架构师尼恩分享了Spring事务的核心知识点,包括事务的两种管理方式(编程式和声明式)、@Transactional注解的五大属性(transactionManager、propagation、isolation、timeout、readOnly、rollbackFor)、事务的七种传播行为、事务隔离级别及其与数据库隔离级别的关系,以及Spring事务的10种失效场景。尼恩还强调了面试中如何给出高质量答案,推荐阅读《尼恩Java面试宝典PDF》以提升面试表现。更多技术资料可在公众号【技术自由圈】获取。
|
1月前
|
存储 缓存 网络协议
计算机网络常见面试题(二):浏览器中输入URL返回页面过程、HTTP协议特点,GET、POST的区别,Cookie与Session
计算机网络常见面试题(二):浏览器中输入URL返回页面过程、HTTP协议特点、状态码、报文格式,GET、POST的区别,DNS的解析过程、数字证书、Cookie与Session,对称加密和非对称加密
|
2月前
|
编译器
经典面试题:变量的声明和定义有什么区别
在编程领域,变量的“声明”与“定义”是经典面试题之一。声明告诉编译器一个变量的存在,但不分配内存,通常包含变量类型和名称;而定义则为变量分配内存空间,一个变量必须至少被定义一次。简而言之,声明是告知变量形式,定义则是实际创建变量并准备使用。
|
2月前
|
XML 前端开发 Java
Spring,SpringBoot和SpringMVC的关系以及区别 —— 超准确,可当面试题!!!也可供零基础学习
本文阐述了Spring、Spring Boot和Spring MVC的关系与区别,指出Spring是一个轻量级、一站式、模块化的应用程序开发框架,Spring MVC是Spring的一个子框架,专注于Web应用和网络接口开发,而Spring Boot则是对Spring的封装,用于简化Spring应用的开发。
202 0
Spring,SpringBoot和SpringMVC的关系以及区别 —— 超准确,可当面试题!!!也可供零基础学习
|
2月前
|
前端开发 小程序 JavaScript
面试官:px、em、rem、vw、rpx 之间有什么区别?
面试官:px、em、rem、vw、rpx 之间有什么区别?
63 0

热门文章

最新文章