ES6:WeakSet,Set,Map,WeakMap
Set 是一种叫做集合的数据结构,Map 是一种叫做字典的数据结构。
Set
- Set是一个集合,里面的值都是唯一的,没有重复的。
- Set中可以是任何数据类型,并且添加数据时会进行严格比较,重复数据无法加入。
- Set 本身是一个构造函数,用来生成 Set 数据结构。
- Set 函数可以接受一个数组(或者具有 iterable 接口的其他数据结构)作为参数,用来初始化。
- Set 对象允许你存储任何类型的值,无论是原始值或者是对象引用。它类似于数组,但是成员的值都是唯一的,没有重复的值。
1 | const s = new Set()[2, 3, 5, 4, 5, 2, 2].forEach((x) => s.add(x)) |
Set 中的特殊值
Set 对象存储的值总是唯一的,所以需要判断两个值是否恒等。有几个特殊值需要特殊对待:
- +0 与 -0 在存储判断唯一性的时候是恒等的,所以不重复;
- undefined 与 undefined 是恒等的,所以不重复;
- NaN 与 NaN 是不恒等的,但是在 Set 中认为 NaN 与 NaN 相等,所有只能存在一个,不重复。
Set 的属性
size:返回集合所包含元素的数量。
1 | const items = new Set([1, 2, 3, 4, 5, 5, 5, 5]) |
Set 实例对象的方法
- add(value):添加某个值,返回 Set 结构本身(可以链式调用)。
- delete(value):删除某个值,删除成功返回 true,否则返回 false。
- has(value):返回一个布尔值,表示该值是否为 Set 的成员。
- clear():清除所有成员,没有返回值。
1 | s.add(1).add(2).add(2) |
遍历方法
- keys():返回键名的遍历器。
- values():返回键值的遍历器。
- entries():返回键值对的遍历器。
- forEach():使用回调函数遍历每个成员。
由于 Set 结构没有键名,只有键值(或者说键名和键值是同一个值),所以 keys 方法和 values 方法的行为完全一致。
1 | let set = new Set(['red', 'green', 'blue']) |
Array 和 Set 对比
- Array 的 indexOf 方法比 Set 的 has 方法效率低下
- Set 不含有重复值(可以利用这个特性实现对一个数组的去重)
- Set 通过 delete 方法删除某个值,而 Array 只能通过 splice。两者的使用方便程度前者更优
- Array 的很多新方法 map、filter、some、every 等是 Set 没有的(但是通过两者可以互相转换来使用)
Set 的应用
1、Array.from 方法可以将 Set 结构转为数组。
1 | const items = new Set([1, 2, 3, 4, 5]) |
2、数组去重
1 | Array.from(new Set(array)) |
3、数组的map和filter方法也可以间接用于set
1 | set = new Set([...set].map((x) => x * 2)) |
4、实现并集 (Union)、交集 (Intersect) 和差集
1 | let a = new Set([1, 2, 3]) |
WeakSet
- 弱引用Set。只能存储对象,不能存储其他类型。且只保持对其中对象的弱引用,若外部无对此对象的引用,或者对象被删除,则WeakSet中将不再有此对象。
- 因为成员都是弱引用,随时可能消失,遍历不能保证成员的存在。所以 WeakSet 不能遍历。
- WeakSet 结构与 Set 类似,也是不重复的值的集合。
- 成员都是数组和类似数组的对象,若调用 add() 方法时传入了非数组和类似数组的对象的参数,就会抛出错误。
- 成员都是弱引用,可以被垃圾回收机制回收,可以用来保存 DOM 节点,不容易造成内存泄漏。
- WeakSet 不可迭代,因此不能被用在 for-of 等循环中。
- WeakSet 没有 size 属性。
Map
Map是一个键值对。
Map与Object的区别是:
- Object的key只能是String和Symbol类型,而Map的key可以是任何基本类型(String, Number, Boolean, undefined, NaN….)或对象类型(Map, Set, Object, Function , Symbol , null….)
- Map有size属性,可以方便的获取Map的长度,但是Object无法直接获取长度
Map 的属性:
- size: 返回集合所包含元素的数量
Map 对象的方法:
- set(key, val): 向 Map 中添加新元素
- get(key): 通过键值查找特定的数值并返回
- has(key): 判断 Map 对象中是否有 Key 所对应的值,有返回 true,否则返回 false
- delete(key): 通过键值从 Map 中移除对应的数据
- clear(): 将这个 Map 中的所有元素删除
1 | const m = new Map() |
WeakMap
弱引用Map。WeakMap有如下特点:
- WeakMap的key只能是对象,不能是基本类型,且对象不计入垃圾回收机制
- WeakMap没有keys、values、entries、size方法
- WeakMap没有遍历操作,无法遍历
WeakMap和WeakSet的作用,可以用来存储DOM节点,保持与DOM节点相关的数据,当DOM节点被删除后,集合中的数据自动删除,
这样就不必担心移除DOM节点时的内存泄漏了。