HTMLCollection对象和NodeList对象
前言
首先我们先来看下面的demo,假如我们需要给所有的li字体变一个颜色。
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
</head>
<body>
	<ul id="list">
		<li>aaaaaaa</li>
		<li>aaaaaaa</li>
		<li>aaaaaaa</li>
		<li>aaaaaaa</li>
	</ul>
</body>
</html>
下面我们将通过两种方式来实现需求。
childNodes
首先我们先来通过childNodes来获取li。
var list = document.getElementById('list');
var lis = list.childNodes;
console.log(lis);

此时需要注意的是,通过childNodes获取的list里面的子节点,数量远远超过了li的数量,原因是在js当中,节点的分类当中不仅仅包括了标签,连同文本、注释等等都会被包括在内。所以当我们获取内容时,连同li之外的节点也找到了。
下面是js当中节点的常见分类:

那么此时如果我们直接给li设置color属性就会直接报错:
	for(var i=0;i<lis.length;i++) {
		lis[i].style.color = 'red'
	}
错误如下:
HTMLCollection 和 NodeList.html:21 Uncaught TypeError: Cannot set property 'color' of undefined
如果想要设置样式,需要在代码中判断一下节点的类型:
for(var i=0;i<lis.length;i++) {
		if(lis[i].nodeType === 1) {
			lis[i].style.color = 'red'
		}
	}
通过nodeType判断节点类型是否是一个元素,如果是再来设置样式。
children
其实我们还可以采用更简单的形式来进行需求的实现:
var list = document.getElementById('list');
var lis = list.children;
for(var i=0;i<lis.length;i++){
  lis[i].style.color = 'red'
}
在上面的代码中,我们将childNodes换成了children,这样我们直接获取了list当中所有的li,并且仅仅获取了li。
这样我们直接在循环中完成了样式的设置。
相对于上面的写法,我们会发现简单了不少。
HTMLCollection 和 NodeList
细心的同学应该会发现一个小问题,就是当我们使用nodeList和children获取所有的li后,打印出来的对象并不一样。
这是通过nodeList打印出来的结果:

下面这是通过children打印出来的结果:

你会发现二者一个是nodeList对象,一个是HTMLCollection对象。
下面我们来聊聊这两个对象。
首先,当我们获取元素时,如果通过下面的api获取元素就可以获得一个HTMLCollection对象:
1:getElementsByTagName() 
2:document.forms.item()
3: document.forms.namedItem()
而如果通过下面的方式将会获得一个NodeList对象:
childNodes
querySelectorAll()
getElementsByClassName()[一些旧版本的浏览器也返回NodeList对象]
如果仅仅从表面看,这两个对象其实非常相似,都是类数组对象,但是二者却有着一个最大的区别:一个是元素集合(HTMLCollection)一个是节点集合(NodeList)。
在元素集合当中仅仅包括元素标签,而节点集合还可能包括其他类型的节点。
二者之间在使用上还有一点区别,在HTMLCollection中除了可以使用索引获取元素以外,还可以使用name、id来获取元素。而NodeList仅仅可以通过索引来获取元素。
当然,这两个对象也存在一些相同的地方:
二者都是类数组对象,具有length属性,但是却不能够使用数组的方法
二者都可以通过类似数组的方式,使用索引获取元素。
Tip: HTMLCollection可以理解为是NodeList的子对象,后者包括前者,前者是继承自后者。
动态集合
HTMLCollection和NodeList都是动态集合,例如下面的例子:
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
</head>
<body>
	<ul id="list"></ul>
</body>
<script type="text/javascript">
	var list = document.getElementById('list');
	console.log(list)
	var li = document.createElement('li');
	list.appendChild(li);
	console.log(list)
</script>
</html>
虽然在插入节点之前console了结果,但是依然是最新的插入节点之后的结果:

querySelectorAll
需要注意的是,虽然querySelectAll也会产生一个NodeList对象,但是却是NodeStaticList,是一个静态集合,这一点较为特殊,并不是一个实时的对象,需要额外的注意。
HTMLCollection对象和NodeList对象的更多相关文章
- HTMLCollection 对象和NodeList 对象
		
获取html元素有三种方法,其中通过类名和标签获取的结果为一个HTMLCollection对象. HTMLCollection对象可以理解为一个包含html元素的数组(但不是数组),可以通过索引[ ] ...
 - NodeList对象的特点
		
nodeList对象的特点1,nodeList是一种类数组对象,用于保存一组有序的节点.2,通过方括号来访问nodeList的值,有item方法与length属性.3,它并不是Array的实例,没有数 ...
 - 简述JavaScript对象、数组对象与类数组对象
		
问题引出 在上图给出的文档中,用JavaScript获取那个a标签,要用什么办法呢?相信第一反应一定是使用document.getElementsByTagName('a')[0]来获取.同样的,在使 ...
 - Document对象和window对象
		
window对象--- 代表浏览器中的一个打开的窗口或者框架,window对象会在<body>或者<frameset>每次出现时被自动创建,在客户端JavaScript中,Wi ...
 - 6、JavaScript进阶篇③——浏览器对象、Dom对象
		
一.浏览器对象 1. window对象 window对象是BOM的核心,window对象指当前的浏览器窗口. window对象方法: 注意:在JavaScript基础篇中,已讲解了部分属性,windo ...
 - jQuery 源码解析(七) jQuery对象和DOM对象的互相转换
		
jQuery对象是一个类数组对象,它保存的是对应的DOM的引用,我们可以直接用[]获取某个索引内的DOM节点,也可以用get方法获取某个索引内的DOM节点,还可以用toArray()方法把jQuery ...
 - 判断一个对象是jQuery对象还是DOM对象
		
今天调试一段代码的时候,看到其中一个变量,想知道它到底是jquery对象还是dom对象. 虽然直接console出这个对象,看它的内部可以判断出来.但是我想有没有什么更方便的方法呢. 后来我想到了一个 ...
 - 一种简单,轻量,灵活的C#对象转Json对象的方案(续)
		
本文参考资料 一种简单,轻量,灵活的C#对象转Json对象的方案 [源码]Literacy 快速反射读写对象属性,字段 一段废话 之前我已经介绍了这个方案的名称为JsonBuilder,这套方案最大的 ...
 - jQuery对象和DOM对象的区别
		
jQuery对象和DOM对象使用说明,需要的朋友可以参考下.1.jQuery对象和DOM对象第一次学习jQuery,经常分辨不清哪些是jQuery对象,哪些是 DOM对象,因此需要重点了解jQuery ...
 
随机推荐
- LocalDateTime、LocalDate、Long、Date、String 相互转换
			
DateTimeFormatter dateTimeFormatter1 = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"); ...
 - [转载]springboot--常用注解--@configration、@Bean
			
springboot--常用注解--@configration.@Bean @Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME ...
 - C# 数组(5) 持续更新
			
同一类型和不同类型的多个对象 使用同一类型的多个对象,使用集合和数组. 使用不同类型的多个对象,使用Tuple(元组). 初始化数组 ]; myArray 存放在栈中,而 myArray 的内容 放在 ...
 - 2018-2019 ACM-ICPC Nordic Collegiate Programming Contest (NCPC 2018)  A. Altruistic Amphibians  (DP)
			
题目链接:https://codeforc.es/gym/101933/problem/A 题意:有 n 只青蛙在一个坑里面,要求可以跳出坑的青蛙的最大数量.每个青蛙有 3 种属性:l 为青蛙一次可以 ...
 - ACM-ICPC 2017 西安赛区现场赛 K. LOVER II   &&  LibreOJ#6062. 「2017 山东一轮集训 Day2」Pair(线段树)
			
题目链接:西安:https://nanti.jisuanke.com/t/20759 (计蒜客的数据应该有误,题目和 LOJ 的大同小异,题解以 LOJ 为准) LOJ:https://l ...
 - C#  StmpClient使用 网络(四)
			
发送邮件 //SmtpClient client = new SmtpClient("smtp.qq.com"); //client.EnableSsl = true; //cli ...
 - 3 Servlet、Filter使用
			
1 使用Servlet获取数据 使用Servlet获取前端的数据,在后端从控制台中打印出前端的数据,前端页面如下图 前端页面程序:需要注意的是form的提交,以及input的不同类型对应的显示不同 & ...
 - 洛谷 P4933 大师
			
题面 (实名推荐:本题的出题人小哥哥打球暴帅哦!(APIO/CTSC/WC的时候一起打过球w,而且大学在我隔壁喔) ) 没仔细看数据范围的时候真是摸不着头脑...还以为要 O(N^2) dp 爆锤.. ...
 - 北京清北 综合强化班 Day4
			
财富(treasure) Time Limit:1000ms Memory Limit:128MB 题目描述 LYK有n个小伙伴.每个小伙伴有一个身高hi. 这个游戏是这样的,LYK生活的环境是以 ...
 - 【CUDA 基础】5.3 减少全局内存访问
			
title: [CUDA 基础]5.3 减少全局内存访问 categories: - CUDA - Freshman tags: - 共享内存 - 归约 toc: true date: 2018-06 ...