Map、Set、WeakMap 和 WeakSet

都是 ES6引入的集合类型

Map(映射)

Map 是一种键值对集合,键可以是任意类型(对象、函数、原始值),保持插入顺序,可直接迭代。

常用方法:

js 复制代码
const map = new Map();
map.set('name', '张三'); // 添加键值对
map.set(1, '数字一');
map.set({id: 1}, '对象作为键');

console.log(map.get('name')); // '张三'
console.log(map.has(1)); // true
console.log(map.size); // 3

map.delete(1); // 删除键
map.clear(); // 清空

使用场景:

  • 需要键不是字符串/数字的情况
  • 需要保持插入顺序的集合
  • 频繁增删键值对的场景

Set(集合)

Set 是值的集合,每个值都是唯一的,保持插入顺序,可直接迭代。

常用方法:

js 复制代码
const set = new Set();
set.add(1);
set.add('text');
set.add({name: 'John'});

console.log(set.has(1)); // true
console.log(set.size); // 3

set.delete('text'); // 删除值
set.clear(); // 清空

使用场景:

  • 数组去重
  • 存储唯一值列表
  • 快速查找是否存在某值

WeakMap(弱映射)

WeakMap 是键必须是对象的 Map,键是弱引用,不可迭代,没有 size 属性。

常用方法:

js 复制代码
const weakMap = new WeakMap();
let obj = {};

weakMap.set(obj, '私有数据');
console.log(weakMap.get(obj)); // '私有数据'
weakMap.delete(obj);

使用场景:

  • 存储对象的私有数据
  • 需要与对象生命周期绑定的数据
  • 避免内存泄漏的场景

WeakSet(弱集合)

WeakSet 是值必须是对象的 Set,值是弱引用,不可迭代,没有 size 属性。

特点:

  • 值必须是对象
  • 值是弱引用(不影响垃圾回收)
  • 不可迭代
  • 没有 size 属性

常用方法:

js 复制代码
const weakSet = new WeakSet();
let obj = {};

weakSet.add(obj);
console.log(weakSet.has(obj)); // true
weakSet.delete(obj);

使用场景:

  • 标记对象(如已处理过的对象)
  • 存储临时对象集合
  • 需要自动清理的场景
相关推荐
凤凰战士芭比Q15 分钟前
web中间件——Nginx
前端·nginx·中间件
一 乐44 分钟前
点餐|智能点餐系统|基于java+ Springboot的动端的点餐系统小程序(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·小程序·论文
视图猿人1 小时前
RxJS基本使用及在next.js中使用的例子
开发语言·javascript
bitbitDown2 小时前
从零打造一个 Vite 脚手架工具:比你想象的简单多了
前端·javascript·面试
liangshanbo12152 小时前
CSS 数学函数完全指南:从基础计算到高级动画
前端·css
码上成长3 小时前
GraphQL:让前端自己决定要什么数据
前端·后端·graphql
冴羽3 小时前
为什么在 JavaScript 中 NaN !== NaN?背后藏着 40 年的技术故事
前端·javascript·node.js
久爱@勿忘3 小时前
vue下载项目内静态文件
前端·javascript·vue.js
前端炒粉3 小时前
21.搜索二维矩阵 II
前端·javascript·算法·矩阵
合作小小程序员小小店4 小时前
web网页开发,在线%台球俱乐部管理%系统,基于Idea,html,css,jQuery,jsp,java,ssm,mysql。
java·前端·jdk·intellij-idea·jquery·web