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);

使用场景:

  • 标记对象(如已处理过的对象)
  • 存储临时对象集合
  • 需要自动清理的场景
相关推荐
一只会跑会跳会发疯的猴子14 分钟前
ajax访问阿里云天气接口,获取7天天气
前端·ajax·okhttp
利刃大大16 分钟前
【在线五子棋对战】五、前端扫盲:html && css && javascript && ajax && jquery && websocket
前端·javascript·html
石小石Orz22 分钟前
被谷歌插件劝退,我半小时学会了油猴脚本开发
前端
安心不心安37 分钟前
React状态管理——zustand
javascript·react.js·ecmascript
阁下何不同风起?42 分钟前
前端导出PDF(适配ios Safari浏览器)
前端·pdf
zhangxingchao1 小时前
Flutter网络编程与数据存储技术
前端
啪叽1 小时前
探索鲜为人知的浏览器API:document.currentScript的实用案例
前端·javascript·dom
我是谁谁1 小时前
Vue3 组合式 API 核心宏详解:defineProps、defineEmits、defineExpose
javascript·vue.js