JavaScript 中的 Map 和 Set:你不得不知的 ES6 新特性!

一、Set:值唯一性的保证

Set 对象类似于数组,但它只存储唯一的值。这意味着,即使你多次添加相同的值,Set 中也只会保留一个。这使得 Set 非常适合用于去重、判断元素是否存在等场景。

核心方法:

  • add(value): 向 Set 中添加一个新值。
  • delete(value): 从 Set 中删除一个值。
  • has(value): 判断 Set 中是否包含某个值。
  • clear(): 清空 Set 中的所有值。
  • size: 返回 Set 中元素的数量。

示例:

javascript 复制代码
const mySet = new Set();
mySet.add(1);
mySet.add(2);
mySet.add(2); // 重复添加,只会保留一个 2
mySet.add('hello');

console.log(mySet); // Set(3) { 1, 2, 'hello' }
console.log(mySet.has(2)); // true
console.log(mySet.size); // 3
mySet.delete(2);
console.log(mySet); // Set(2) { 1, 'hello' }

应用场景:

  • 数据去重:快速去除数组中的重复元素。
  • 元素存在性判断:高效地检查元素是否在一个集合中。
  • 唯一标识符生成:生成一组唯一的标识符。

二、Map:键值对的完美伴侣

Map 对象存储键值对,类似于对象,但它允许使用任意数据类型作为键,而不仅仅是字符串。这使得 Map 比对象更加灵活和强大。 Map 中的键值对按照插入顺序排列,方便迭代遍历。

核心方法:

  • set(key, value): 向 Map 中添加一个键值对。
  • get(key): 获取与指定键关联的值。
  • delete(key): 删除指定键的键值对。
  • has(key): 判断 Map 中是否包含指定键。
  • clear(): 清空 Map 中的所有键值对。
  • size: 返回 Map 中键值对的数量。
  • entries(), keys(), values(): 分别返回键值对、键和值的迭代器。

示例:

javascript 复制代码
const myMap = new Map();
myMap.set('name', 'John');
myMap.set(1, 'one');
myMap.set({a:1}, 'object');

console.log(myMap); // Map(3) { 'name' => 'John', 1 => 'one', { a: 1 } => 'object' }
console.log(myMap.get('name')); // John
console.log(myMap.has(1)); // true
console.log(myMap.size); // 3

应用场景:

  • 缓存:存储数据,提高程序性能。
  • 数据关联:建立不同数据之间的映射关系。
  • 对象存储:存储复杂对象,避免对象键名冲突。
相关推荐
tager4 分钟前
告别布局烦恼!H5自适应布局最佳实践
前端·css·前端框架
BUG收容所所长4 分钟前
HoverMask与SelectedMask——如何让低代码平台的交互体验更加直观?
前端·javascript·设计
植物系青年10 分钟前
可视化编辑 🔧 前端用“低代码”方式动态变更网页内容
前端·低代码
四月友人A11 分钟前
Chrome DevTools 深度挖掘:90%开发者都不知道的调试秘籍
前端·chrome
Mintopia20 分钟前
🌐AIGC:从硅芯片中孕育的缪斯女神
前端·javascript·aigc
去码头整点薯条吃24 分钟前
React源码(一):认识JSX
前端
掘金安东尼24 分钟前
⏰前端周刊第425期(2025年7月28日–8月3日)
前端·javascript·面试
namehu25 分钟前
为什么我的margin-top被转换为vw而不是vh?
javascript·css·postcss
小old弟26 分钟前
💯 React自定义Hook:封装数据请求
前端
雪中何以赠君别26 分钟前
Vite + Axios + Nginx 环境变量与代理配置笔记
前端·javascript·vue.js