ES6迭代器(三)

2023-05-23 08:43:50 浏览数 (1)

自定义可迭代对象:

除了内置的可迭代对象,我们还可以自定义对象的迭代行为,使其具备可迭代的能力。

示例:

代码语言:javascript复制
// 自定义可迭代对象示例
let range = {
  start: 1,
  end: 5,

  [Symbol.iterator]() {
    let current = this.start;

    return {
      next: () => {
        if (current <= this.end) {
          return { value: current  , done: false };
        } else {
          return { value: undefined, done: true };
        }
      }
    };
  }
};

for (let num of range) {
  console.log(num);
}
// 输出:
//   1
//   2
//   3
//   4
//   5

在上面的示例中,我们定义了一个自定义可迭代对象range,并实现了Symbol.iterator方法来返回一个迭代器对象。通过迭代器对象的next()方法,我们实现了从start到end的递增序列的迭代。

迭代器的优势和应用场景:

  • 简化遍历过程:使用迭代器可以将集合的遍历过程进行抽象和封装,使得遍历更加简单、直观和易于理解。
  • 惰性计算:迭代器可以实现惰性计算,即只在需要时才生成下一个元素,节省了计算和内存资源。
  • 支持无限序列:通过迭代器,可以实现无限序列的生成和遍历,而不需要事先生成所有的元素。
  • 兼容for...of循环:实现迭代器协议的对象可以直接使用for...of循环进行遍历,提高了代码的可读性和可维护性。

0 人点赞