Set和Map数据结构
一、Set
它类似于数组,但是成员的值都是唯一的,没有重复的值。Set 本身是一个构造函数,用来生成 Set 数据结构。
1 | const s = new Set(); |
Set 函数可以接受一个数组(或类似数组的对象)作为参数,用来初始化。
1 | // 例一 |
去除数组重复成员的方法。
1 | // 去除数组的重复成员 |
二、Set 实例的属性和方法
- 属性
- Set.prototype.constructor:构造函数,默认就是Set函数。
- Set.prototype.size:返回Set实例的成员总数。
- 方法
- add(value):添加某个值,返回Set结构本身。
- delete(value):删除某个值,返回一个布尔值,表示删除是否成功。
- has(value):返回一个布尔值,表示该值是否为Set的成员。
- clear():清除所有成员,没有返回值。
三、遍历操作
- keys():返回键名的遍历器
- values():返回键值的遍历器
- entries():返回键值对的遍历器
- forEach():使用回调函数遍历每个成员
1 | let set = new Set(['red', 'green', 'blue']); |
四、Map
它类似于对象,也是键值对的集合,但是“键”的范围不限于字符串,各种类型的值(包括对象)都可以当作键。
1 | const map = new Map([ |
五、Map 实例的属性和方法
- 属性
- Map.prototype.constructor:构造函数,默认就是Map函数。
- Map.prototype.size:返回Map实例的成员总数。
- 方法
- set(key, value):set方法设置键名key对应的键值为value,然后返回整个 Map 结构。如果key已经有值,则键值会被更新,否则就新生成该键。可以采用链式写法。
- get(key):get方法读取key对应的键值,如果找不到key,返回undefined。
- has(key):has方法返回一个布尔值,表示某个键是否在当前 Map 对象之中。
- delete(key):delete方法删除某个键,返回true。如果删除失败,返回false。
- clear(): clear方法清除所有成员,没有返回值。
六、遍历操作
和 Set 一样