JavaScript 给对象写迭代器,使对象可以使用for...of

一、用到 对象 转 Map

   var obj = {
      "a": 1,
      "b": 2,
      "c": 3
    };
    var map = new Map();
    for(let key in obj){
      map.set(key,obj[key]);
    }
    console.log(map);
    
     for(let item of obj){
        console.log(item)//报错
     }

二、添加迭代器对象的方法

   // 定义对象的迭 代器对象
      var obj = {
        "a": 1,
        "b": 2,
        "c": 3,
        // 迭代器
        [Symbol.iterator]() {
          var index = 0;
          let map = new Map();
          // object 对象转 map

          for(let key in this){           
            map.set(key,this[key]);
          }
          var Entries = [...map.entries()];
          return {
            next() {
              if (index < map.size) {
              //自定义要返回的数据形式
                return {
                  value: Entries[index++],
                  done: false
                }
              }
              return {
                value: undefined,
                done: true
              }
            }
          }
        }
      }
     for(let item of obj){
        console.log(item)//就不会报错
     }

在这里插入图片描述

三、生成器的方法

利用生成器 生成 迭代器对象。

生成器函数

function * name{
yield 1;
}

  • yeild 产出一个值,
  • 调用next(),函数才执行
    var obj = {
        "a": 1,
        "b": 2,
        "c": 3,
        [Symbol.iterator]:function*() {
          var index = 0;
          let map = new Map();
          // object 对象转 map
          for(let key in this){           
            map.set(key,this[key]);
          }
          var Entries = [...map.entries()];
          for(let item of Entries){
            yield Entries[index++];
          }        
        }
      }
      for(let item of obj){
        console.log(item)
      }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值