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 都是静态集合。
    • var children = document.body.childNodes;
      children.length; //
      document.body.appendChild(document.createElement('p'));
      children.length; // 19 // 文档增加一个子节点,NodeList 实例 children length 属性就增加了1
  • 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
    • HTMLCollection 实例都是动态集合,节点的变化会实时反映在集合中
    • 如果元素节点有 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
  • HTMLCollection.prototype.length
    • 返回 HTMLCollection 实例包含的成员数量

      document.links.length    //
  • 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 接口的更多相关文章

  1. (84)Wangdao.com第十八天_JavaScript 文档对象模型 DOM

    文档对象模型 DOM DOM 是 JavaScript 操作网页的接口, 全称为“文档对象模型”(Document Object Model). 作用是将网页转为一个 JavaScript 对象,从而 ...

  2. (84)Wangdao.com第十八天_JavaScript Promise 对象

    Promise 对象 是 JavaScript 的异步操作解决方案,为异步操作提供统一接口. 目前 JavaScript 原生支持 Promise 对象 它起到代理作用(proxy),充当异步操作与回 ...

  3. querySelector()与querySelectorAll()的区别及NodeList和HTMLCollection对象的区别

    querySelector().Document.Element类型均可调用该方法. 当用Document类型调用querySelector()方法时,会在文档元素范围内查找匹配的元素:而当用Elem ...

  4. javascript高级程序设计---NodeList和HTMLCollection

    节点对象都是单个节点,但是有时会需要一种数据结构,能够容纳多个节点.DOM提供两种接口,用于部署这种节点的集合分别是NodeList和HTMLCollection MDN上的定义: NodeList: ...

  5. DOM中的NodeList与HTMLCollection

    最近在看<Javascript高级程序设计>的时候,看到了这样一句话:“理解NodeList和HTMLCollection,是从整体上透彻理解DOM的关键所在.”,所以觉得应该写一篇关于N ...

  6. Delphi 的接口机制——接口操作的编译器实现过程(1)

    学习COM编程技术也快有半个月了,这期间看了很多资料和别人的程序源码,也尝试了用delphi.C++.C#编写COM程序,个人感觉Delphi是最好上手的.C++的模版生成的代码太过复杂繁琐,大量使用 ...

  7. 深入理解javascript中的动态集合——NodeList、HTMLCollection和NamedNodeMap

    × 目录 [1]NodeList [2]HTMLCollection [3]NamedNodeMap[4]注意事项 前面的话 一说起动态集合,多数人可能都有所了解.但是,如果再深入些,有哪些动态集合, ...

  8. PHP - 接口 - 多接口

    /* * 使用多接口 */ //定义接口1 interface IPerosn_one{ public function eat(); } //定义接口2 interface IPerson_two{ ...

  9. java:接口特性 接口与抽象类/普通类的区别

    接口 书面定义: Java接口是一系列方法的声明,是一些方法特征的集合,一个接口只有方法的特征没有方法的实现,因此这些方法可以在不同的地方被不同的类实现,而这些实现可以具有不同的行为(功能). 在ja ...

随机推荐

  1. day18 集合框架(JCF)

    集合框架(JCF)java collections framework 框架:为了实现某一目的/功能而预先提供的一系列封装好的具有继承或实现关系的类与接口. 1.这种框架是高性能的,对基本类集(动态数 ...

  2. Android应用程序国际化

    前情提要 在Android应用程序中, 可以轻松更改语言, 以适应国际化标准 一些用户拥有多种语言习惯, 因此, 应用程序不能依赖设备默认语言环境, 必须提供更改显示语言的程序功能 本文章探寻持久化语 ...

  3. MacOS下使用远程桌面VNC

    1 分为一个server 和 viewer,server端就是可以加入组然后允许远程连接,viewer就是远程连接端 2 server下载地址 https://www.realvnc.com/en/c ...

  4. js中精度问题以及解决方案

    js中的数字按照IEEE 754的标准,使用64位双精度浮点型来表示.其中符号位S,指数位E,尾数位M分别占了1,11,52位,并且在ES5规范中指出了指数位E的取值范围是[-1074, 971]. ...

  5. websocket 与Socket.IO介绍

    一  websocket WebSocket是html5新增加的一种通信协议,目前流行的浏览器都支持这个协议,例如 Chrome,Safrie,Firefox,Opera,IE等等,对该协议支持最早的 ...

  6. 设计模式三: 代理模式(Proxy) -- JDK的实现方式

    简介 代理模式属于行为型模式的一种, 控制对其他对象的访问, 起到中介作用. 代理模式核心角色: 真实角色,代理角色; 按实现方式不同分为静态代理和动态代理两种; 意图 控制对其它对象的访问. 类图 ...

  7. Sublime text3 连接sftp/ftp(远程服务器)

    1.按下Ctrl + Shift + P调出命令面板2.在输入框中输入Sftp,按回车下载3.建一个新的文件夹放到左边的项目栏中4.右击文件夹,选中SFTP/FTP,点击Map to Remote5. ...

  8. 题解 P5065 【[Ynoi2014]不归之人与望眼欲穿的人们】

    出现了一篇跑得炒鸡慢的题解! noteskey 无 fuck 说,好像就是整个数列分块然后合并区间...什么的吧 对于每块内部就是算一下前缀信息.后缀信息(就是以 第一个点/最后一个点 为一个边界,不 ...

  9. 51nod--1174 区间中最大的数 (RMQ)

    题目: 1174 区间中最大的数 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 给出一个有N个数的序列,编号0 - N - 1.进行Q次查询,查询编号i至j ...

  10. 解决爬虫中遇到的js加密问题之有道登录js逆向解析

    具体实现在github上面(有详细的步骤): https://github.com/WYL-BruceLong/Spider_JS_ReverseParsin