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

应用场景:

  • 缓存:存储数据,提高程序性能。
  • 数据关联:建立不同数据之间的映射关系。
  • 对象存储:存储复杂对象,避免对象键名冲突。
相关推荐
1024小神几秒前
在GitHub action中使用添加项目中配置文件的值为环境变量
前端·javascript
龙骑utr5 分钟前
qiankun微应用动态设置静态资源访问路径
javascript
Jasmin Tin Wei6 分钟前
css易混淆的知识点
开发语言·javascript·ecmascript
齐尹秦9 分钟前
CSS 列表样式学习笔记
前端
wsz777713 分钟前
js封装系列(一)
javascript
Mnxj13 分钟前
渐变边框设计
前端
用户76787977373216 分钟前
由Umi升级到Next方案
前端·next.js
快乐的小前端17 分钟前
TypeScript基础一
前端
北凉温华18 分钟前
UniApp项目中的多服务环境配置与跨域代理实现
前端
源柒19 分钟前
Vue3与Vite构建高性能记账应用 - LedgerX架构解析
前端