for...of为什么不能遍历Object对象

       因为能够被for...of正常遍历的,都需要实现一个遍历器Iterator。而数组、字符串、Set、Map结构,早就内置好了Iterator(迭代器),它们的原型中都有一个Symbol.iterator方法,而Object对象并没有实现这个接口,使得它无法被for...of遍历。例如:

Array.prototype[Symbol.iterator];

// ƒ values() { [native code] }

String.prototype[Symbol.iterator];

// ƒ [Symbol.iterator]() { [native code] }

Set.prototype[Symbol.iterator];

// ƒ values() { [native code] }

Map.prototype[Symbol.iterator];

// ƒ entries() { [native code] }

Object.prototype[Symbol.iterator];

// undefined

今天(2018/12/14)补充说明一下,如何让对象可以被for of 遍历,当然是给它添加遍历器,代码如下:

      Object.prototype[Symbol.iterator] = function() {
        let index = 0;
        let arr = Object.entries(this);
        let length = arr.length;
        return {
          next: () => {
            let key = arr[index] && arr[index][0];
            let text = arr[index] && arr[index][1];
            let value = { [key]: text };
            let done = index >= length;
            index++;
            return { value, done };
          }
        };
      };

今天(2020/7/17)补充说明一下如何使用生成器实现遍历,代码如下:

      Object.prototype[Symbol.iterator] = function*() {
        let index = 0;
        let arr = Object.entries(this);
        let length = arr.length;
        while (true) {
            if (index >= length) {
                return false
            } else {
                let key = arr[index] && arr[index][0];
                let text = arr[index] && arr[index][1];
                let value = { [key]: text };
                index++;
                yield value
            }
        }
      };

 

  • 20
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值