ES8 中的 Object.entries/Object.values 与 for-of 实现 JavaScript 中的迭代器

阅读时长 5 分钟读完

在 JavaScript 中,迭代器是一种非常常见的概念,它用于遍历数组、对象等集合类型的数据。在 ES8 中,新增了 Object.entries 和 Object.values 方法,以及 for-of 循环语句,这些新特性使得 JavaScript 中的迭代器更加易用、高效。本文将详细介绍 Object.entries/Object.values 和 for-of 循环语句的用法,并给出相关示例代码。

Object.entries/Object.values

Object.entries 和 Object.values 是 ES8 中新增的两个方法,它们都用于遍历对象的属性。其中,Object.entries 方法返回一个由对象的键值对组成的数组,而 Object.values 方法则返回一个由对象的属性值组成的数组。下面是它们的用法:

-- -------------------- ---- -------
----- --- - - ---- ------ ---- -- --

-- -------------- --
--- ------ ----- ------ -- -------------------- -
  -------------------- -----------
-
-- -------
--   ---- ---
--   ---- --

-- ------------- --
--- ------ ----- -- ------------------- -
  -------------------
-
-- -------
--   ---
--   --

可以看到,使用 Object.entries 方法可以同时获取对象的键和值,而 Object.values 方法只能获取对象的值。

for-of 循环语句

for-of 循环语句是 ES6 中新增的语法,它用于遍历可迭代对象(如数组、字符串、Set、Map 等)。在 ES8 中,for-of 循环语句可以与 Object.entries/Object.values 方法配合使用,来实现对对象属性的遍历。下面是一个示例:

可以看到,使用 for-of 循环语句和 Object.entries 方法,可以非常方便地遍历对象的属性。

迭代器的实现

在 JavaScript 中,迭代器是一种非常常见的概念,它用于遍历集合类型的数据。在 ES6 中,引入了迭代器协议,它规定了一个对象必须实现一个名为 Symbol.iterator 的方法,该方法返回一个迭代器对象。迭代器对象必须实现一个名为 next 的方法,该方法返回一个包含 value 和 done 两个属性的对象,其中 value 表示当前迭代到的值,done 表示迭代是否结束。下面是一个示例:

可以看到,通过调用数组的 Symbol.iterator 方法,可以获取一个迭代器对象,然后通过调用 next 方法,可以逐个迭代数组中的元素。

在 ES8 中,通过使用 Object.entries/Object.values 方法和 for-of 循环语句,可以非常方便地实现迭代器。下面是一个示例:

-- -------------------- ---- -------
----- --- - - ---- ------ ---- -- --
----- ------- - --------------------

----- -------- - -
  ------------------- -
    --- ----- - --
    ------ -
      ------ -
        -- ------ - --------------- -
          ----- ----- ------ - -----------------
          ------ - ------ ----- ------- ----- ----- --
        - ---- -
          ------ - ------ ---------- ----- ---- --
        -
      -
    --
  -
--

--- ------ ----- ------ -- --------- -
  -------------------- -----------
-
-- -------
--   ---- ---
--   ---- --

可以看到,通过使用 Object.entries 方法获取对象的键值对数组,然后通过迭代器协议实现一个迭代器对象,最后使用 for-of 循环语句遍历该对象,可以非常方便地实现对对象属性的迭代。

总结

ES8 中新增的 Object.entries/Object.values 方法和 for-of 循环语句,使得 JavaScript 中的迭代器更加易用、高效。通过使用它们,可以非常方便地遍历对象属性,并实现迭代器协议。在实际开发中,我们应该充分利用这些新特性,提高代码的可读性和效率。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/655ea9f6d2f5e1655d8cf8ae

纠错
反馈