ECMAScript 2019: 如何使用 Map 和 Set

阅读时长 4 分钟读完

ECMAScript 2019: 如何使用 Map 和 Set

Map 和 Set 是 JavaScript 中的两个新数据结构,它们分别提供了一种键值对和一种无重复值的集合。这两个数据结构在 ES2015 中就已经被引入,而在 ES2019 中又有了一些新的特性和用法。

Map

Map 可以看作是一种更加灵活的 Object,它可以使用任意类型的值作为键,而不仅仅是字符串或 Symbol。Map 的键值对可以通过 set 方法添加,也可以通过构造函数初始化。Map 的 size 属性可以获取其键值对的数量。

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

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

Map 还有一些方便的方法:

  • has(key):判断 Map 中是否存在指定键。
  • delete(key):删除指定键的键值对。
  • clear():清空 Map 中的所有键值对。

除了以上方法,Map 还有一个 forEach 方法,可以遍历其键值对并执行指定操作。forEach 的第一个参数是一个回调函数,该函数接受三个参数:键值对的值、键、Map 对象本身。

Set

Set 是一种无重复值的集合,可以用来去重或者判断某个值是否存在。Set 的值可以通过 add 方法添加,也可以通过构造函数初始化。Set 的 size 属性可以获取其值的数量。

Set 还有一些方便的方法:

  • has(value):判断 Set 中是否存在指定值。
  • delete(value):删除指定值。
  • clear():清空 Set 中的所有值。

除了以上方法,Set 还有一个 forEach 方法,可以遍历其值并执行指定操作。forEach 的第一个参数是一个回调函数,该函数接受三个参数:值、同样的值、Set 对象本身。

总结

Map 和 Set 是两个非常实用的数据结构,它们可以用来解决很多问题。例如,Map 可以用来存储对象之间的关系,Set 可以用来去重数组。在使用 Map 和 Set 时,请注意它们的特性和限制。例如,Map 的键可以是任意类型的值,但是在比较时会使用严格相等运算符(===);Set 的值也可以是任意类型的值,但是 NaN 在 Set 中等于自身,而且 Set 中的值是不可变的。

希望本文可以帮助你更好地理解和使用 Map 和 Set。如果你有任何问题或建议,欢迎在评论区留言。

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

纠错
反馈