js中迭代器Iterator的使用

介绍

Iterator迭代器是用于遍历对象的一种接口,可以给不同的数据结构提供统一的循环方式实现遍历,可以与es6提供的for…of搭配使用。

具备原生的Iterator接口的数据结构

  • Array
  • String
  • Set
  • Map
  • 函数中的argument对象

使用

  • Symbol.iterator:数据集合默认的遍历器生成函数,执行该函数便会返回一个遍历器对象

    • 遍历器对象
      • next():返回⼀个描述当前成员的信息对象,具有value和done两个属性,名称不可更改
  • 原生迭代器的数据结构使用

{
  const arr = [1, 2, 3, 4];
  const fn = arr[Symbol.iterator]();
  console.log(fn.next());
  console.log(fn.next());
  console.log(fn.next());
  console.log(fn.next()); // {value: 4, done: false}
  console.log(fn.next()); // {value: undefined, done: true}
}
  • 自定义对象迭代器的使用
{
  let obj = {
    name: "dog",
    weight: 123,
    height: 12,
    [Symbol.iterator]() {
      // 索引
      let index = 0;
      let values = Object.values(obj);
      return {
        next() {
          if (index < values.length) {
            return {
              value: values[index++],
              done: false,
            };
          } else {
            return { done: true };
          }
        },
      };
    },
  };

  for (const value of obj) {
    console.log(value); // dog  123 12
  }
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值