--- title: WeakSet slug: Web/JavaScript/Reference/Global_Objects/WeakSet tags: - Class - ECMAScript 2015 - JavaScript - WeakSet translation_of: Web/JavaScript/Reference/Global_Objects/WeakSet ---
{{JSRef}}

WeakSet オブジェクトは、コレクションに弱く参照されたオブジェクトを格納することができます。

解説

WeakSet オブジェクトはコレクションオブジェクトです。 {{jsxref("Set")}} と同様に、 WeakSet 内の各オブジェクトは一度だけ存在します。すなわち、 WeakSet コレクション内で固有になります。

{{jsxref("Set")}} オブジェクトとの主な違いは下記の通りです。

使用例: 循環参照の検出

自分自身を再帰的に呼び出す関数は、どのオブジェクトが処理済みであるかを追跡することで、循環したデータ構造を防ぐ必要があります。

WeakSet はこの目的に理想的です。

// Execute a callback on everything stored inside an object
function execRecursively(fn, subject, _refs = null){
  if(!_refs)
    _refs = new WeakSet();

  // Avoid infinite recursion
  if(_refs.has(subject))
    return;

  fn(subject);
  if("object" === typeof subject){
    _refs.add(subject);
    for(let key in subject)
      execRecursively(fn, subject[key], _refs);
  }
}

const foo = {
  foo: "Foo",
  bar: {
    bar: "Bar"
  }
};

foo.bar.baz = foo; // Circular reference!
execRecursively(obj => console.log(obj), foo);

ここで、 WeakSet は最初の実行時に作成され、その後の関数呼び出しのたびに (内部の _refs 引数を使用して) 渡されます。

オブジェクトの数や探索順序は重要ではないので、オブジェクトの参照を追跡するには WeakSet のほうが {{jsxref("Set")}} よりも、特に巨大な数のオブジェクトを処理する場合にはよりふさわしい (そして性能もよい) ものです。

コンストラクター

{{jsxref("WeakSet/WeakSet", "WeakSet()")}}
新しいWeakSetオブジェクトを生成します。

インスタンスメソッド

{{jsxref("WeakSet.add", "WeakSet.prototype.add(value)")}}
valueWeakSet オブジェクトに追加します。
{{jsxref("WeakSet.delete", "WeakSet.prototype.delete(value)")}}
valueWeakSet オブジェクトから削除します。削除後、 WeakSet.prototype.has(value)false を返します。
{{jsxref("WeakSet.has", "WeakSet.prototype.has(value)")}}
valueWeakSet オブジェクト内の要素に含まれているかどうかを示す論理値を返します。

WeakSet オブジェクトの使用

const ws = new WeakSet();
const foo = {};
const bar = {};

ws.add(foo);
ws.add(bar);

ws.has(foo);    // true
ws.has(bar);    // true

ws.delete(foo); // foo を set から削除
ws.has(foo);    // false, foo は削除済み
ws.has(bar);    // true, bar は残っている

foo !== bar であることに注意してください。これらは似たオブジェクトですが、まったく同じオブジェクトではありません。したがって、両方のオブジェクトが set に追加されます。

仕様書

仕様書
{{SpecName('ESDraft', '#sec-weakset-objects', 'WeakSet')}}

ブラウザーの互換性

{{Compat("javascript.builtins.WeakSet")}}

関連情報