ECMAScript 6 新增的 Set 是一种新集合类型,为这门语言带来集合数据结构。Set 在很多方面都像是加强的 Map,这是因为它们的大多数 API 和行为都是共有的。

1. 基本API

使用new关键字和Set()构造函数可以创建一个空集合

  1. const s = new Set();

如果想在创建的同时初始化实例,则可以给 Set 构造函数传入一个可迭代对象,其中需要包含插入到新集合实例中的元素:

  1. // 使用数组初始化集合
  2. const s1 = new Set(["val1", "val2", "val3"]);
  3. alert(s1.size); // 3 内部键值对数量
  4. // 使用自定义迭代器初始化集合
  5. const s2 = new Set({
  6. [Symbol.iterator]: function*() {
  7. yield "val1";
  8. yield "val2";
  9. yield "val3";
  10. }
  11. });
  12. alert(s2.size); // 3

和map类似,初始化之后,可以使用 add()增加值,使用 has()查询,通过 size 取得元素数量,以及使用 delete()和 clear()删除元素:

  1. const s = new Set();
  2. alert(s.has("Matt")); // false
  3. alert(s.size); // 0
  4. s.add("Matt")
  5. .add("Frisbie");
  6. alert(s.has("Matt")); // true
  7. alert(s.size); // 2
  8. s.delete("Matt");
  9. alert(s.has("Matt")); // false
  10. alert(s.has("Frisbie")); // true
  11. alert(s.size); // 1
  12. s.clear(); // 销毁集合实例中的所有值
  13. alert(s.has("Matt")); // false
  14. alert(s.has("Frisbie")); // false
  15. alert(s.size); // 0

add()返回集合的实例,所以可以将多个添加操作连缀起来,包括初始化:

  1. const s = new Set().add("val1");
  2. s.add("val2")
  3. .add("val3");
  4. alert(s.size); // 3

方法名 作用
add() 往set对象中新增一个数据,返回当前set对象
delete() 删除set对象中的某条数据
clear() 清空set对象
has() 判断set对象中是否有某个数据,有返回true,否则false
forEach() 遍历set对象
size 属性,获取set对象数据长度