ES6中的Map与Set

在ES6中,Map和Set是两种新的数据结构,用于存储和操作数据。它们提供了更灵活和高效的方式来处理集合和键值对。

Map:

Map 是一种键值对的集合,类似于传统的对象(Object),但具有更多的功能。以下是 Map 的一些特点:

  • 键可以是任意数据类型,包括基本类型和对象引用。
  • 保持插入顺序,即插入的键值对将按照插入的顺序进行迭代。
  • 可以使用 size 属性获取 Map 的大小。
  • 提供了丰富的方法来操作和查询数据,如 set()、get()、has()、delete() 等。
      以下是使用 Map 的示例代码:
javascript 复制代码
const map = new Map();

map.set("key1", "value1");
map.set("key2", "value2");

console.log(map.get("key1")); // 输出 "value1"
console.log(map.size); // 输出 2
console.log(map.has("key2")); // 输出 true

map.delete("key2");
console.log(map.size); // 输出 1

Set:

Set 是一种唯一值的集合,它不允许重复的元素。以下是 Set 的一些特点:

  • 只能存储唯一的值,重复的值将被忽略。
  • 保持插入顺序,即插入的元素将按照插入的顺序进行迭代。
  • 可以使用 size 属性获取 Set 的大小。
  • 提供了丰富的方法来操作和查询数据,如 add()、has()、delete() 等。
      以下是使用 Set 的示例代码:
javascript 复制代码
const set = new Set();

set.add("value1");
set.add("value2");
set.add("value2"); // 重复的值将被忽略

console.log(set.size); // 输出 2
console.log(set.has("value1")); // 输出 true

set.delete("value2");
console.log(set.size); // 输出 1

Map和Set在处理数据时的区别

数据结构:

  • Map 是键值对的集合,每个键都唯一且与一个值相关联。Set 是唯一值的集合,不允许重复的元素。

键的类型:

  • Map 的键可以是任意数据类型,包括基本类型和对象引用。Set 存储的是唯一值,可以是任意数据类型。

迭代顺序:

  • Map 保持插入顺序,即插入的键值对将按照插入的顺序进行迭代。Set 也保持插入顺序,即插入的元素将按照插入的顺序进行迭代。

重复值:

  • Map 允许相同的值关联不同的键,每个键都是唯一的。Set 不允许重复的值存在,如果尝试插入重复的值,将被忽略。

大小和查询操作:

  • Map 提供了 size 属性来获取集合的大小,可以使用 get() 方法根据键获取对应的值。Set 也提供了 size 属性来获取集合的大小,可以使用 has() 方法来检查集合中是否存在某个值。

删除操作:

  • Map 提供了 delete() 方法来根据键删除键值对。Set 提供了 delete() 方法来删除集合中的某个值。
相关推荐
光影少年4 分钟前
中级前端需要会的东西都有那些?
前端·学习·前端框架
琢磨先生TT11 分钟前
为什么很多后台系统功能不少,看起来却还是很廉价?
前端·vue.js·设计
ekuoleung12 分钟前
量化平台中的 DSL 设计与实现:从规则树到可执行策略
前端·后端
小研说技术18 分钟前
实时通信对比,一场MCP协议的技术革命
前端·后端·面试
kyriewen22 分钟前
React Hooks原理:为什么不能写在if里?揭开Hook的“魔法”面纱
前端·react.js·前端框架
敲代码的彭于晏24 分钟前
Claude Code Token 烧得太快?这8个方案帮你立省90%!
前端·ai编程·claude
可视之道26 分钟前
设备拓扑图中的实时状态映射与动画策略:告警闪烁、流向动画、质量码怎么共存
前端
涂兵兵_青石疏影27 分钟前
绘制图像-clip方法
前端
之歆43 分钟前
Day03_HTML 列表、表格、表单完整指南(下)
android·javascript·html
焦糖玛奇朵婷1 小时前
解锁扭蛋机小程序的五大优势
java·大数据·服务器·前端·小程序