一. 什么是遍历器

1. 遍历器对象(Iterator)

遍历器对象本质上是一个指针对象,该对象有一个next方法,调用next方法返回一个

含有value和done属性的对象{value: val/undefined, done: false/true}。

const iterator = {
next() {
return {value: val/undefined, done: false/true}
}
}

另外遍历器对象可以简单的通过Generator函数(遍历器生成函数)生成。

const gen = function* testGen(){ yield ....}

2. iterator接口

也可以叫做遍历器生成函数。一些数据称之为可遍历数据,本质上是因为数据结构

本身带有iterator接口,即具有属性[Symbol.iterator],该属性对应一个遍历器生成函数。

iterator接口对应的遍历工具主要是for...of循环。其余工具还有: ...(扩展运算符)、Array.from()等。

使用这些工具的时候,会默认调用[Symbol.iterator]方法,遍历方法返回的遍历器。

所以,一个数据是否可遍历,取决于是否具有[Symbol.iterator]属性。

而可以通过给数据添加该属性,使本身不可遍历的数据变成可遍历数据。

原生具有iterator接口的数据类型有:

Array
String
Map
Set
TypedArray
Arguments对象
NodeList对象

除了上面的数据类型,其他数据类型想要可遍历,都必须添加[Symbol.iterator]属性。

其中类数组的对象,可以直接使用数组的[Symbol.iterator]属性。其他对象不可以!

let iterable = { //属性值是数值和length
0: 'a',
1: 'b',
2: 'c',
length: 3,
[Symbol.iterator]: Array.prototype[Symbol.iterator] //不添加该属性之前,不可遍历,类数组只有NodeList,Arguments,String可遍历
};
for (let item of iterable) {
console.log(item); // 'a', 'b', 'c'
}

如果自定义的话,可以使用Generator函数赋值。

也可以自定义一个函数,按照遍历机制生成一个遍历器对象。不符合会导致崩溃。

3. iterator接口使用场合

以下场景自动调用iterator的构造函数。

1.解构赋值

数组/Set/Map的解构赋值

let [a,...b] = [1,2,3,4];
a;//
b;// [2,3,4]

对象的解构赋值

let { foo, ...bar} = {foo: 1, a:1, b:2,c:3}
foo; //
bar; // {a:1,b:2,c:3}

2. 扩展运算符

3.yield*

后面是一个遍历器,即可遍历对象。相当于自动调用for...of循环

let generator = function* () {
yield 1;
yield* [2,3,4];
yield 5;
};
// 相当于
let generator = function* () {
yield 1;
for(let i of [2,3,4]) {
yield i;
}
yield 5;
};

4.使用数组传参的方法

数组只会遍历键是数字的值。非数字的键名不遍历。

for...of
Array.from()
Set()
Map()
WeakMap
WeakSet
Promise.all()
Promise.race()

4. 遍历器的return方法和throw方法

详见

return方法非正常触发的条件是:

1)for...of循环遇到break

2) for...of循环中抛出异常

其中如果遇到抛出异常,会先调用return方法,然后再抛出异常

5. 遍历方法返回遍历器的数据结构

数组
Set
Map
URLSearchParams

上面数据结构调用keys(),values(),entries()返回一个遍历器对象

let arr = [12];
arr.r = 2;
// 返回一个遍历器对象
let it = arr.keys(); //Array Iterator
it.next(); //{value: 0, done: false}
it.next();// {value:undefined, done:true}
// 由此可知,数组遍历的时候只遍历键名是数值的成员

6. for...of循环优点

1. 比for循环书写简单

2.forEach不能中断,for...of可以中断

3.for...in主要用于遍历对象,用于数组时,会遍历非数值的键名。

详情查询

遍历器Iterator--指针对象的更多相关文章

  1. C++泛型编程(1)--自己实现C++迭代器/遍历器 iterator

    1.原理 迭代器又称为遍历器,用于访问容器中的数据,迭代器旨在算法和容器之间搭建访问的桥梁,从而使算法和数据分离,不用关心数据具体的存储细节.具体的原理描述请参考以下两个博客: [1].C++迭代器 ...

  2. Iterator、for..of,for...in和自定义遍历器**

    Iterator.for..of,for...in和自定义遍历器 Iterator: var arr = [1,2,3,4,5]; var ite = arr[Symbol.iterator](); ...

  3. Iterator(遍历器) 和 for...of 循环

    是generator的前置知识 generator :https://www.cnblogs.com/wangtong111/p/11322961.html 遍历器(Iterator)就是这样一种机制 ...

  4. 疑问:Iterator 遍历器和数据集合各种遍历方法的区别

    https://es6.ruanyifeng.com/#docs/iterator Iterator(遍历器)的概念 Iterator 接口主要供for...of消费 Iterator 的遍历过程是: ...

  5. ES6的 Iterator 遍历器到底是什么?

    这节课要讲的是ES6中的Iterator. for...of为啥不遍历Object对象 第十三节我们讲了简单又实用的for...of,我们可以使用它来遍历数组,字符串,Set和Map结构,但是有没有发 ...

  6. Iterator遍历器 调用Symbol.Iterator属性,遍历器对象。

    Iterator实现原理 创建一个指针对象,指向当前数据结构的起始位置.也就是说,遍历器对象本质上,就是一个指针对象. 第一次调用指针对象的next方法,可以将指针指向数据结构的第一个成员. 第二次调 ...

  7. ES6的Iterator遍历器

    JS表示集合的对象主要有Array.Set.Object.Map,在以前,遍历它们需要使用2种不同的方法,而现在,JS提出了Iterator机制,可以给不同的数据结构提供统一的遍历方法,就是for…o ...

  8. iterator [ɪtə'reɪtə] 遍历器

    lterator 遍历器 遍历器是一种接口,它为不同的数据结构提供了统一的访问机制. 如果一个数据结构具有遍历器接口,那么就可以依次处理该数据结构的成员. 当前 javascript 用来表示集合的数 ...

  9. 【前端】【javascript】es6中的遍历器接口Iterator

    好久没发文章啦-.-为了证明我还活着,我决定从笔记里面抓一篇还算不乱比较像文章的发出来... 这些笔记是我在学es6的时候断断续续记录的,最近会一份一份整理陆陆续续发出来,顺便也自己再看一遍.我学习e ...

随机推荐

  1. poj 1852&3684 题解

    poj 1852 3684 这两题思路相似就放在一起. 1852 题意 一块长为L长度单位的板子(从0开始)上有很多只蚂蚁,给出它们的位置,它们的方向不确定,速度为每秒一长度单位,当两只蚂蚁相遇的时候 ...

  2. xsy 2414【CF587C】Duff in the Army

    Description [题目描述]: 最近有一场战争发生,Duff是战争里一名士兵,Malek是她的长官. 他们的国家——Andarz Gu有n个城市(编号为1到n),总共有n-1条道路,每条道路连 ...

  3. Python-03-流程控制

    一.if判断语句 1. if...else if 条件: 满足条件时要做的事情1 满足条件时要做的事情2 ...... else: 不满足条件时要做的事情1 不满足条件时要做的事情2 ...... # ...

  4. Python3 - 随便说一下

    Ⅰ编程语言基础知识 ⅡPython 语言概述 Ⅰ编程语言基础知识 编程语言总体分以为机器语言.汇编语言.高级语言: 机器语言:计算机硬件能够直接使用的编程语言,二进制的集合,属于低级语言. 汇编语言: ...

  5. WUSTOJ 1324: Base64 Coding(Java)未解决,求题解

    题目链接:1324: Base64 Coding 资料:ASCII码表 原文是英文,而且篇幅较长.因此下面不粘贴原文,只写中文大意. Description Base64是一种编码算法.它的工作原理是 ...

  6. 【计数DP】种树

    种树 题目描述 事实上,小X邀请两位奆老来的目的远不止是玩斗地主,主要是为了抓来苦力,替他的后花园种树……小X的后花园是环形的,他想在花园周围均匀地种上n棵树,但是奆老花园的土壤当然非同寻常,每个位置 ...

  7. Sping Aop日志实现(五)--使用Mybatis注解保存日志

  8. LOJ3049 [十二省联考2019] 字符串问题 【后缀自动机】【倍增】【拓扑排序】

    题目分析: 建出后缀自动机,然后把A串用倍增定位到后缀自动机上,再把B串用倍增定位到后缀自动机上. SAM上每个点上的A串根据长度从小到大排序,建点,依次连边. 再对于SAM上面每个点,连到儿子的边, ...

  9. Spring Boot学习随记

    由于早年在管理领域耕耘了一段时间,完美错过了Spring的活跃期, 多少对这个经典的技术带有一种遗憾的心态在里面的, 从下面的我的生涯手绘图中大概可以看出来我的经历. 最近由于新介入到了工业数字化领域 ...

  10. 如何做好PPT

    为什么要做ppt 全图型PPT,一张大图做背景,少量的文字---PPT大师Garr Renolds极力推崇的风格 半图型PPT PTT是为了和你的"客户"有效的沟通 好的PPT G ...