Set.prototype.forEach()
Baseline
Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since 2015年7月.
forEach() は Set インターフェイスのメソッドで、指定された関数をこの集合のそれぞれの値に対して一回ずつ、挿入順で実行します。
試してみましょう
function logSetElements(value1, value2, set) {
console.log(`s[${value1}] = ${value2}`);
}
new Set(["foo", "bar", undefined]).forEach(logSetElements);
// 予想される結果: "s[foo] = foo"
// 予想される結果: "s[bar] = bar"
// 予想される結果: "s[undefined] = undefined"
構文
forEach(callbackFn)
forEach(callbackFn, thisArg)
引数
callback-
この集合のそれぞれの項目に対して実行する関数です。この関数は次の引数で呼び出されます。
thisArg省略可-
callbackFnを実行するときn、thisとして使用する値です。
返値
undefined です。
解説
forEach() メソッドは、この Set オブジェクトに実際に存在するそれぞれの値に対して、指定された callback を一回ずつ実行します。削除された値に対しては呼び出しません。ただし、undefined の値をもつ要素に対しては実行します。
callback は 3 つの引数で呼び出されます。
- この要素の値
- この要素のキー
- 走査を行っている
Setオブジェクト
しかし、 Set オブジェクトにキーがないので、最初の 2 つの引数は、両方とも Set に含まれる値です。これにより、他の Map や Array の forEach() メソッドと整合が取れています。
thisArg 引数が forEach() に渡された場合、 callback を呼び出すときにこれが渡され、 this 値として使用されます。渡されなかった場合は、さもなければ、this 値として使用するために undefined 値が渡されます。 this の値が最終的に callback から見える姿は、関数から見た this を決定するための通常のルールに応じて決まります。
それぞれの値は 1 回ずつ処理されますが、 forEach() が終了する前に削除・再追加された場合は例外です。処理される前に削除された値に対しては callback は実行されません。 forEach() が終了する前に追加された新しい値は処理されます。
forEach() は callback 関数を Set オブジェクト内のそれぞれの要素に対して一回ずつ実行します。返値はありません。
例
>Set オブジェクトの内容を出力する
次のコードでは、Set オブジェクト内の各要素に対してログを出力します。
function logSetElements(value1, value2, set) {
console.log(`s[${value1}] = ${value2}`);
}
new Set(["foo", "bar", undefined]).forEach(logSetElements);
// Logs:
// "s[foo] = foo"
// "s[bar] = bar"
// "s[undefined] = undefined"
仕様書
| Specification |
|---|
| ECMAScript® 2026 Language Specification> # sec-set.prototype.foreach> |
ブラウザーの互換性
Loading…