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

1. 基本API:

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

const m = new Set();

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

// 使用数组初始化集合
const s1 = new Set(["val1", "val2", "val3"]);
    alert(s1.size); // 3
// 使用自定义迭代器初始化集合 const s2 = new Set({
      [Symbol.iterator]: function*() {
        yield "val1";
        yield "val2";
        yield "val3";
alert(s2.size); // 3

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

const s = new Set();
alert(s.has("Matt"));
alert(s.size);
s.add("Matt")
 .add("Frisbie");
alert(s.has("Matt"));
alert(s.size);
s.delete("Matt");
alert(s.has("Matt"));
alert(s.has("Frisbie")); // true
alert(s.size);           // 1
s.clear(); // 销毁集合实例中的所有值
alert(s.has("Matt"));    // false
alert(s.has("Frisbie")); // false
alert(s.size);           // 0

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

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

与 Map 类似,Set 可以包含任何 JavaScript 数据类型作为值。集合也使用 SameValueZero 操作 (ECMAScript 内部定义,无法在语言中使用),基本上相当于使用严格对象相等的标准来检查值的匹配性。

const s = new Set();
     const functionVal = function() {};
     const symbolVal = Symbol();
     const objectVal = new Object();
 s.add(functionVal);
s.add(symbolVal);
s.add(objectVal);
alert(s.has(functionVal));
alert(s.has(symbolVal));
alert(s.has(objectVal));
// true
// true
// true
// SameValueZero 检查意味着独立的实例不会冲突 alert(s.has(function() {})); // false