ES2015+学习笔记系列(三)—— 迭代器

迭代器

迭代器(Iterator)是一个接口,任何数据结构只要部署了Iterator 接口(即对象中的属性,Symbol.iterator),就可以完成遍历操作。

  • ES6 创造的新的遍历命令 for…of 循环,Iterator 接口主要供 for…of 消费。(for…in 遍历键名,for…of 遍历键值)

  • 原生具备 iterator 接口的数据(可用 for…of):Array 、Arguments、Set、Map、String、TypedArray、NodeList

  • 工作原理

    • 创建一个指针对象,指向当前数据结构的起始位置
      可迭代对象(如数组)的__proto__里iterator指针对象生成函数为属性名是Symbol.iterator对应的函数,用以构造指针对象
    • 第一次调用对象的 next 方法,指针自动指向数据结构的第一个成员

    iterator指针对象中的next方法

    • 接下来不断调用 next 方法,指针一直往后移动,知道指向最有一个成员
    • 每次调用 next 方法返回一个包含 value 和 done 属性的对象
  let iteratorArr = ['a', 'b', 'c'];
  console.log(iteratorArr);
  //获取Symbol.iterator对应的函数,用以创建对象,在可遍历对象的_proto_上
  let iteratorFunction = iteratorArr[Symbol.iterator];
  //创建指针对象,使用Symbol.iterator对应的函数创建
  let iteratorObj = iteratorArr[Symbol.iterator]();
  console.log(iteratorObj);
  //指针对象上有next方法,调用
  console.log(iteratorObj.next());//{value: "a", done: false}
  console.log(iteratorObj.next());
  console.log(iteratorObj.next());
  console.log(iteratorObj.next());//{value: undefined, done: true}

自定义迭代器遍历对象

 const iteratorData = {
            name: "二班",
            students: ["老二", "雅兴", "张超"],
            [Symbol.iterator]: function () {
                let index = 0;
                let _this = this;
                return {
                    next: function () {
                        if (index < _this.students.length) {
                            const result = { value: _this.students[index], done: false };
                            index++;
                            return result;
                        } else {
                            const result = { value: _this.students[index], done: true };
                            return result;
                        }
                    },
                };
            },
        };
        for (let v of iteratorData) {
            console.log(v);
        }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值