(85)Wangdao.com第十八天_JavaScript NodeList 接口,HTMLCollection 接口
NodeList 接口 HTMLCollection 接口
节点都是单个对象,有时需要一种数据结构,能够容纳多个节点
DOM 提供两种节点集合,用于容纳多个节点:NodeList 和 HTMLCollection
这两种集合都属于接口规范。
许多 DOM 属性和方法,返回的结果是 NodeList 实例或 HTMLCollection 实例。
主要区别是
NodeList 可以包含各种类型的节点
HTMLCollection 只能包含 HTML 元素节点。
NodeList 接口
- NodeList 实例是一个类似数组的对象,可以使用 length 属性和 forEach 方法。但是,它不是数组,不能使用 pop() 或 shift() 之类数组特有的方法。
var children = document.body.childNodes; Array.isArray(children); // false children.length; //
children.forEach(console.log); // forEach() 遍历 NodeList 实例for (var i = 0; i < children.length; i++) { // for 遍历 NodeList 实例
var item = children[i];
}如果 NodeList 实例要使用数组方法,可以将其转为真正的数组
var children = document.body.childNodes;
var nodeArr = Array.prototype.slice.call(children);
- 它的成员是节点对象。
- 通过以下方法可以得到 NodeList 实例
- Node.childNodes
- document.querySelectorAll()等节点搜索方法
- 注意:
- NodeList 实例可能是动态集合,也可能是静态集合。
- 所谓动态集合就是一个活的集合,DOM 删除或新增一个相关节点,都会立刻反映在 NodeList 实例。
- 目前,只有 Node.childNodes 返回的是一个动态集合,其他的 NodeList 都是静态集合。
- NodeList 实例可能是动态集合,也可能是静态集合。
var children = document.body.childNodes;
children.length; //
document.body.appendChild(document.createElement('p'));
children.length; // 19 // 文档增加一个子节点,NodeList 实例children的length属性就增加了1
- NodeList 实例是一个类似数组的对象,可以使用 length 属性和 forEach 方法。但是,它不是数组,不能使用 pop() 或 shift() 之类数组特有的方法。
- NodeList.prototype.length
- 返回 NodeList 实例包含的节点数量。
- 对于那些不存在的 HTML 标签,length 属性返回 0
document.getElementsByTagName('xxx').length; //
- NodeList.prototype.forEach()
- 用于遍历 NodeList 的所有成员。
- 它接受一个回调函数作为参数,每一轮遍历就执行一次这个回调函数
- 用法与数组实例的 forEach() 方法完全一致
var children = document.body.childNodes;
children.forEach(function f(item, i, list) {
// ...
}, this); // forEach方法的第二个参数,用于绑定回调函数内部的this,该参数可省略
// 回调函数f的三个参数依次是
// 当前成员
// 在类数组中的 index
// 当前 NodeList 实例。
- NodeList.prototype.item( posIndex )
- 接受一个整数值作为参数,表示成员的位置,返回该位置上的成员
- 所有类似数组的对象,都可以使用方括号运算符取出成员。一般情况下,都是使用方括号运算符,而不使用
item方法。document.body.childNodes.item(0); // item(0)返回第一个成员
document.body.childNodes[0]; // 最为常用
- 如果参数值大于实际长度,或者索引不合法(比如负数),item方法返回null。
- 如果省略参数,item 方法会报错
- NodeList.prototype.keys(),NodeList.prototype.values(),NodeList.prototype.entries()
- 这三个方法都返回一个 ES6 的遍历器对象
- 可以通过for...of循环遍历获取每一个成员的信息
- 区别在于
- keys()返回键名的遍历器
- values()返回键值的遍历器
- entries()返回的遍历器同时包含键名和键值的信息。
var children = document.body.childNodes; for (var key of children.keys()) {
console.log(key);
}
//
//
//
// ... for (var value of children.values()) {
console.log(value);
}
// #text
// <script>
// ... for (var entry of children.entries()) {
console.log(entry);
}
// Array [ 0, #text ]
// Array [ 1, <script> ]
// ...
HTMLCollection 接口
- 概述
- HTMLCollection 是一个节点对象的集合,只能包含元素节点(element),不能包含其他类型的节点。
- 它的返回值是一个类似数组的对象,但是与NodeList接口不同,HTMLCollection没有forEach方法,只能使用for循环遍历。
- 返回 HTMLCollection 实例的,主要是些 document 对象的集合属性
- 比如 document.forms、document.images、document.links 等等
document.links instanceof HTMLCollection // true
- 比如 document.forms、document.images、document.links 等等
- HTMLCollection 实例都是动态集合,节点的变化会实时反映在集合中
- 返回 HTMLCollection 实例的,主要是些 document 对象的集合属性
- 如果元素节点有 id 或 name 属性,那么 HTMLCollection 实例上面,
- 可以使用 id 属性或 name 属性引用该节点元素。
- 如果没有对应的节点,则返回null
// HTML 代码如下
// <img id="pic" src="http://example.com/foo.jpg"> var pic = document.getElementById('pic');
document.images.pic === pic // true
- 如果元素节点有 id 或 name 属性,那么 HTMLCollection 实例上面,
- HTMLCollection.prototype.length
- 返回 HTMLCollection 实例包含的成员数量
document.links.length //
- 返回 HTMLCollection 实例包含的成员数量
- HTMLCollection.prototype.item()
- item() 方法接受一个整数值作为参数,表示成员的位置,返回该位置上的成员。
- 由于方括号运算符也具有同样作用,而且使用更方便,所以一般情况下,总是使用方括号运算符
- 如果参数值超出成员数量或者不合法(比如小于0),那么 item() 方法返回 null
var c = document.images;
var img0 = c.item(0); var img0 = c[0]; // 更常用 [ ]
- HTMLCollection.prototype.namedItem()
- 参数是一个字符串,表示 id 属性或 name 属性的值,返回对应的元素节点。
- 如果没有对应的节点,则返回null
// HTML 代码如下
// <img id="pic" src="http://example.com/foo.jpg"> var pic = document.getElementById('pic');
document.images.namedItem('pic') === pic // true
(85)Wangdao.com第十八天_JavaScript NodeList 接口,HTMLCollection 接口的更多相关文章
- (84)Wangdao.com第十八天_JavaScript 文档对象模型 DOM
文档对象模型 DOM DOM 是 JavaScript 操作网页的接口, 全称为“文档对象模型”(Document Object Model). 作用是将网页转为一个 JavaScript 对象,从而 ...
- (84)Wangdao.com第十八天_JavaScript Promise 对象
Promise 对象 是 JavaScript 的异步操作解决方案,为异步操作提供统一接口. 目前 JavaScript 原生支持 Promise 对象 它起到代理作用(proxy),充当异步操作与回 ...
- querySelector()与querySelectorAll()的区别及NodeList和HTMLCollection对象的区别
querySelector().Document.Element类型均可调用该方法. 当用Document类型调用querySelector()方法时,会在文档元素范围内查找匹配的元素:而当用Elem ...
- javascript高级程序设计---NodeList和HTMLCollection
节点对象都是单个节点,但是有时会需要一种数据结构,能够容纳多个节点.DOM提供两种接口,用于部署这种节点的集合分别是NodeList和HTMLCollection MDN上的定义: NodeList: ...
- DOM中的NodeList与HTMLCollection
最近在看<Javascript高级程序设计>的时候,看到了这样一句话:“理解NodeList和HTMLCollection,是从整体上透彻理解DOM的关键所在.”,所以觉得应该写一篇关于N ...
- Delphi 的接口机制——接口操作的编译器实现过程(1)
学习COM编程技术也快有半个月了,这期间看了很多资料和别人的程序源码,也尝试了用delphi.C++.C#编写COM程序,个人感觉Delphi是最好上手的.C++的模版生成的代码太过复杂繁琐,大量使用 ...
- 深入理解javascript中的动态集合——NodeList、HTMLCollection和NamedNodeMap
× 目录 [1]NodeList [2]HTMLCollection [3]NamedNodeMap[4]注意事项 前面的话 一说起动态集合,多数人可能都有所了解.但是,如果再深入些,有哪些动态集合, ...
- PHP - 接口 - 多接口
/* * 使用多接口 */ //定义接口1 interface IPerosn_one{ public function eat(); } //定义接口2 interface IPerson_two{ ...
- java:接口特性 接口与抽象类/普通类的区别
接口 书面定义: Java接口是一系列方法的声明,是一些方法特征的集合,一个接口只有方法的特征没有方法的实现,因此这些方法可以在不同的地方被不同的类实现,而这些实现可以具有不同的行为(功能). 在ja ...
随机推荐
- JavaScript 正则表达式基础语法
前言 正则表达式在人们的印象中可能是一堆无法理解的字符,但就是这些符号却实现了字符串的高效操作.通常的情况是,问题本身并不复杂,但没有正则表达式就成了大问题.javascript中的正则表达式作为相当 ...
- Java CAS 比较并且更换值
原文:Java中CAS详解 作者:jayxu无捷之径 在JDK 5之前Java语言是靠synchronized关键字保证同步的,这会导致有锁 锁机制存在以下问题: (1)在多线程竞争下,加锁.释放锁会 ...
- 关于JS中的常用表单验证+正则表达式
一.非空验证 trim:去空格(去掉前后的空格),任何字符串都可以用这个方法.写法为:if(v.trim().length==0),表示如果去掉空格后的字符串的长度为0. <body> & ...
- 网络学习day01_计算机网络与分层思想
2018.9.1 网络学习day01_计算机网络与分层思想 网络安全 计算机网络 分层思想 LAN与WAN LAN(Local Area Network)--局域网 局域网(Local ...
- Django之form表单
https://www.cnblogs.com/liwenzhou/p/8747872.html 1. form组件的介绍 之前web开发的模式,以注册为例: 1. 要有一个注册的页面,页面里面要有f ...
- jquery前端倒计时
function FreshTime(){ // var endtime=new Date("2019/04/15,12:20:12");//结束时间 var endtime = ...
- Lua“控制”C
[前言] Lua语言本身是一个功能非常有限,而比较单调的语言,而且标准库也非常的平庸,它的NB之处就在于,它能和C.C++等高级语言完美“私通”.我们可以使用C.C++语言去给Lua写一个完美的库,让 ...
- Windows 下安装Git工具及基础使用
Git简介 git是很好一个工具使用,可以执行liunx命令,有git环境后windows系统就可以进行shell命令操作,就可以添加其他liunx辅助软件进行执行,git也代码库管理工具,无论是上传 ...
- 20175226 2018-2019-2 《Java程序设计》第四周学习总结
20175226 2018-2019-2 <Java程序设计>第四周学习总结 教材学习内容总结 子类与父类 格式class 子类名 extends 父类名 Object类是所有类的祖先类 ...
- Token令牌管理权限
什么是token HTTP是一种无状态的协议,也就是HTTP没法保存客户端的信息,没办法区分每次请求的不同. Token是服务器生成的一串字符,作为客户端请求的令牌.当第一次登陆后,服务器会分发Ton ...