Iterator遍历器笔记

遍历器

1.概念

1、它是一种接口,为各种不同的数据结构提供统一的访问机制。任何数据结构只要部署Iterator接口,通过next方法就可以完成遍历操作。

2、默认的Iterator接口部署在数据结构的Symbol.iterator属性,数据结构只要有该属性,就认为是可遍历的

3、Symbol.iterator属性名是一个表达式,返回Symbol对象的Iterator属性,要放在方括号内

2.作用

1,为各种数据结构,提供一个统一的、简便的访问接口

2,使数据结构的成员按照某种次序排列

3,为ES6创造了一种新的遍历命令,for…of循环

let arr = ['a', 'b', 'c'];
let iter = arr[Symbol.iterator]();

iter.next() // { value: 'a', done: false }
iter.next() // { value: 'b', done: false }
iter.next() // { value: 'c', done: false }
iter.next() // { value: undefined, done: true }

3.在对象上设置iterator

1,因为确定对象属性遍历顺序不确定,所以object上没有部署iterator接口

2,因为es6加入了Map结构,对象部署遍历接口并不是很必要

3,一个对象如果要具备可被for...of循环调用的 Iterator 接口,就必须在Symbol.iterator的属性上部署遍历器生成方法(原型链上的对象具有该方法也可)

let obj = {
  data: [ 'hello', 'world' ],
  [Symbol.iterator]() {
    const self = this;
    let index = 0;
    return {
      next() {
        if (index < self.data.length) {
          return {
            value: self.data[index++],
            done: false
          };
        }
        return { value: undefined, done: true };
      }
    };
  }
};

4.调用iterator的接口的场景

1,解构赋值

2,扩展运算符(…)。只要部署了iterator接口,就可以对他使用扩展运算符

3,yield*

4,for…of,Array.from(),Map(), Set(), WeakMap(), WeakSet()(比如new Map([['a',1],['b',2]])),Promise.all(),Promise.race()

5.Iterator 接口与 Generator 函数

可以用Generator实现Symbol.iterator()方法

let myIterable = {
  [Symbol.iterator]: function* () {
    yield 1;
    yield 2;
    yield 3;
  }
};
[...myIterable] // [1, 2, 3]

// 或者采用下面的简洁写法

let obj = {
  * [Symbol.iterator]() {
    yield 'hello';
    yield 'world';
  }
};

for (let x of obj) {
  console.log(x);
}
// "hello"
// "world"

上面代码中,Symbol.iterator()方法几乎不用部署任何代码,只要用 yield 命令给出每一步的返回值即可。

  • 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、付费专栏及课程。

余额充值