遍历器与 for...of 循环

Iterator 是什么

  1. Iterator 的作用
    Iterator:遍历器(迭代器)
    for()
    [1, 2].forEach
    new Set().forEach()
    Iterator 也是用来遍历的
  2. 寻找 Iterator
const it = [1,2][Symbol.iterator]();
  1. 使用 Iterator
const it = [1, 2][Symbol.iterator]();
console.log(it.next());		// {value: 1, done: false}
console.log(it.next());		// {value: 2, done: false}
console.log(it.next());		// {value: undefined, done: true}

it 可遍历对象(可迭代对象)
Symbol.iterator 可遍历对象的生成方法

  1. 什么是 Iterator
    Symbol.iterator (可遍历对象的生成方法) -> it(可遍历对象) -> it.next() -> it.next() -> … (直到done为true)

Iterator 解惑

  1. 为什么需要 Iterator 遍历器
    因为可以统一一个遍历的方式
  2. 如何更方便的使用 iterator 去遍历
    我们一般不会直接使用 Iterator 去遍历
    for … of

for…of 的用法

  1. 认识for…of
const arr = [1, 2, 3];
for (const item of arr) {
	console.log(item);
}

for…of 循环只会遍历出那些 done 为 false 时,对应的 value 值

  1. 与 break、continue 一起使用
const arr = [1, 2, 3];
for (const item of arr) {
	if (item === 2) {
		// break;
		continue;
	}
	console.log(item);
}
  1. 在 for…of 中取得数组的索引
const arr = [1, 2, 3];
for (const key of arr.keys()) {
	console.log(key);
}
// 遍历数组值
const arr = [1, 2, 3];
for (const value of arr.values()) {
	console.log(value);
}
const arr = [1, 2, 3];
for (const entrie of arr.entries()) {
	console.log(entrie);
}
for (const [index, value] of arr.entries()) {
	console.log(index, value);
}

原生可遍历和非原生可遍历

  1. 什么是可遍历
    只要有 Symbol.iterator 方法,并且这个方法可以生成可遍历对象,就是可遍历的
    只要可遍历,就可以使用 for…of循环来统一遍历

  2. 原生可遍历的有哪些
    数组
    字符串
    Set
    Map
    arguments
    NodeList

  3. 非原生可遍历的有哪些
    一般的对象
    有length和索引属性的对象

const obj = {
	0: 'tom',
	1: 'mail',
	length: 2
};
// 简单的方法,用 Array 的方法
obj[Symbol.iterator] = Array.protoype[Symbol.iterator];

使用了 Iterator 的场合

  • 原生可遍历的
    Array 数组
    String 字符串
    Set
    Map
    函数的 arguments 对象
    NodeList 对象
  1. 数组的展开运算符
    只要是可遍历的,就可以用数组的方式展开
  2. 数组的解构赋值
    只要是可遍历的,就可以用数组的方式解构赋值
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 遍历是一种可以遍历数据结构中所有元素的接口,它的作用类似于指针。而遍历对象则是具体的实现了遍历接口的对象。每个具体的数据结构都需要自己实现自己的遍历对象,以便于我们通过遍历对数据结构进行操作。 ### 回答2: 遍历(Iterator)是一种统一的接口,用来遍历各种不同的数据结构。它可以定义在任何对象上,通过持续返回序列中的下一个值来实现遍历遍历通过两个方法来实现:一个是返回当前位置的值的next方法,另一个是返回遍历是否结束的布尔值的done方法。 遍历对象(Iterator Object)则是实现了遍历接口的对象。它可以通过Symbol.iterator方法返回,也就是说,一个对象的Symbol.iterator方法是它的默认的遍历生成函数。遍历对象具有next、return和throw三个方法,其中next方法用来返回序列中的下一个值,return方法用来终止遍历,throw方法用来抛出异常。 由于遍历对象实现了遍历接口,因此在使用遍历的地方,只要返回了遍历对象,就可以进行遍历操作。而且,通过遍历对象的next方法,可以依次取得序列中的下一个值。 值得注意的是,遍历对象不仅可以用于数组和Set等数据结构,还可以用于自定义的数据结构。通过在对象上定义Symbol.iterator方法,并返回一个遍历对象,我们就可以使得对象可以被for...of循环和其他遍历操作使用。 综上所述,遍历遍历对象之间的关系是,遍历是一种接口,通过返回当前位置的值和判断遍历是否结束的布尔值实现遍历;而遍历对象则是具体实现了遍历接口的对象,可以通过Symbol.iterator方法返回,用来在各种具体的数据结构上进行遍历操作。 ### 回答3: 遍历指的是一种基于迭代模式的接口,它提供了一个统一的方法来遍历数据结构中的元素。而遍历对象是实现了遍历接口的对象。 在JavaScript中,我们可以使用`Symbol.iterator`来创建一个遍历对象,这个对象必须具有一个`next`方法,用来返回数据结构中的下一个值。`next`方法返回一个具有`value`和`done`两个属性的对象,`value`表示当前迭代的值,`done`表示迭代是否结束。 遍历对象是可以被循环调用的,每次调用`next`方法都会返回当前的值并且更新迭代的状态,直到迭代结束`done`为`true`。我们可以使用`for...of`循环遍历遍历对象,它会自动调用`next`方法并获取返回的值。 遍历遍历对象之间的关系是一一对应的,一个遍历对象是一个可迭代的数据结构,它就像一个指针一样在数据结构中移动并获取对应的值。不同的数据结构有不同的遍历方式,但它们的遍历对象都遵循了相同的接口规范,即具有`next`方法返回迭代的值。 总之,遍历遍历对象之间是一种接口与实现的关系,遍历对象是通过实现遍历接口来实现遍历数据结构的功能。通过遍历对象,我们可以方便地迭代访问数据结构中的值,而不用关心具体的遍历实现方式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值