このページはコミュニティーの尽力で英語から翻訳されました。MDN Web Docs コミュニティーについてもっと知り、仲間になるにはこちらから。

View in English Always switch to English

Set.prototype.difference()

Baseline 2024
最近利用可能

June 2024以降、この機能は最新のバージョンの端末およびブラウザーで動作します。古い端末やブラウザーでは動作しないことがあります。

difference()Set インスタンスのメソッドで、集合を一つ受け取り、この Set に含まれており、与えられた集合に含まれない要素を含む新しい Set を返します。

構文

js
difference(other)

引数

other

Set オブジェクト、または Set 風オブジェクトです。

返値

新しい Set オブジェクトで、この Set に含まれる要素で、other 集合には含まれない要素が入ったものです。

解説

数学的な記法では、差 (difference) は次のように定義されます。

AB={xAxB}A\setminus B = \{x\in A\mid x\notin B\}

ベン図を使うとこうなります。

2 つの円が重なり合うベン図。A と B の差は、A の B と重なり合わない部分です。

difference() は、Set 風オブジェクトを other 引数として受け入れます。this は、ユーザーコードを呼び出すことなく、this オブジェクトに格納されているデータに直接アクセスするため、実際の Set インスタンスであることが要求されます。その後、その動作は thisother のサイズに依存します。

  • this の中の要素が other.size よりも多かった場合、otherkeys() メソッドを呼び出すことで走査し、this の中のすべての要素のうち other にない要素で新しい Set を構築します。
  • そうでなければ、this の要素を走査し、this の要素 e のうち、other.has(e)偽値を返すすべてを含む新しい Set を構築します。

返される Set の要素の順序は、this の順序と同じです。

difference() の使用

次の例では、奇数(10 未満)と完全平方(10 未満)の集合の差を計算します。結果は、完全平方ではない奇数の集合となります。

js
const odds = new Set([1, 3, 5, 7, 9]);
const squares = new Set([1, 4, 9]);
console.log(odds.difference(squares)); // Set(3) { 3, 5, 7 }

仕様書

仕様書
ECMAScript® 2027 Language Specification
# sec-set.prototype.difference

ブラウザーの互換性

関連情報