我的编程空间,编程开发者的网络收藏夹
学习永远不晚

详解如何优雅迭代JavaScript字面对象

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

详解如何优雅迭代JavaScript字面对象

为什么要实现自定义迭代器

因为在JavaScript中字面量对象是不支持迭代的

如何实现JavaScript字面量对象迭代

  • 只要正确实现字面对象的Symbol.iterator这个属性所对应的迭代器函数即可
  • 注意⚠️该迭代器函数只是一个函数,而不是真正的迭代器
  • 迭代器是一个对象,需要提供next函数来提供给类似for of forEach这种迭代函数使用

实现方法

第一种使用比较简单的遍历来实现

let obj = {uname: "zhangsan"};
obj[Symbol.iterator] = function () {
  const keys = Object.keys(this);
  let index = 0;
  return {
    next() {
      return {
        value: obj[keys[index++]],
        done: index > keys.length
      }
    }
  };
};

let iterator = obj[Symbol.iterator]();

console.log(iterator.next());
//{value: 'zhangsan', done: false}

obj.uname='sudongyu'

iterator = obj[Symbol.iterator]();

console.log(iterator.next());
//{value: 'sudongyu', done: false}

第二种使用生成器函数来实现


function object2iterator(obj){
    obj[Symbol.iterator]=function* () {
        let properties = Object.keys(this);
        for (let i of properties) {
            yield [i, this[i]];
        }
    }
    return obj
}

生成器详细API 请参考 mdn

解析为什么生成器函数要这样设计

以下纯个人理解,如果有歧义就当我放屁~ 哈哈哈

  • 迭代器函数是一个函数,这样每次调用都会为将要return的迭代器中的next函数创建一个全新的词法作用域
  • 这样每次在创建新的迭代器时,执行iterator.next()的时候就可以利用闭包访问到属于自己的外层词法环境中的变量,在方法一中也就是能够从index为0开始迭代
  • 这样每个独立的迭代器对象就能相互隔离~

注意⚠️:我还想表达以下几个观点:

  • JavaScript中的对象只是数据的载体,集合
  • 所以我们不能把对象中的函数或者属性作为对象的一部分
  • 对象的属性和函数它们只是一个间接的关系,虽然有点难理解,但是我还是想表达一下这个观点
  • 打个比方来讲,你(对象)身上的钱(属性或者对象上的函数)只是你作为了它暂时的载体,并不意味着这个钱就属于你身体的一部分

总结

到此这篇关于如何优雅迭代JavaScript字面对象的文章就介绍到这了,更多相关迭代JS字面对象内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

详解如何优雅迭代JavaScript字面对象

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

JavaScript 代理模式:揭秘面向对象编程的优雅解决方案

JavaScript 代理模式是一种强大且灵活的机制,允许我们创建动态对象,让对象的行为和属性能够根据需要进行修改,从而实现面向对象编程的优雅解决方案。
JavaScript 代理模式:揭秘面向对象编程的优雅解决方案
2024-03-09

python如何连接可迭代对象中的字符串

这篇文章主要介绍python如何连接可迭代对象中的字符串,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!连接可迭代对象中的字符串在处理字符串时,有时需要通过连接列表、元组等可迭代对象内的一系列字符串来创建单个字符串。这
2023-06-27

详解Java如何优雅的实现字典翻译

当我们在Java应用程序中需要对字典属性进行转换返回给前端时,如何简单、方便、并且优雅的处理是一个重要问题。在本文中,我们将介绍如何使用Java中的序列化机制来优雅地实现字典值的翻译,从而简化开发
2023-05-18

Javascript如何实现对象扁平化实例详解

这篇文章主要给大家介绍了关于Javascript如何实现对象扁平化的扁平化处理简而言之就是对对象中的对象提取出来,放在一个对象里面,形象的说就是把儿子的后代当成自己的儿子,下面相关资料,需要的朋友可以参考下
2022-11-13

详解Go语言如何利用高阶函数写出优雅的代码

高阶函数(Hiher-order Function)定义为:满足下列条件之一的函数:接收一个或多个函数作为参数;返回值是一个函数。本文为大家介绍了如何利用高阶函数写出优雅的代码,希望对大家有所帮助
2023-01-05

编程热搜

目录