Set.prototype.forEach()
Метод forEach() выполняет функцию по одному разу для каждого элемента из Set в порядке их расположения.
Интерактивный пример
Синтаксис
mySet.forEach(callback[, thisArg])
Параметры
callback-
Функция, которая будет выполнена для каждого элемента, принимает три параметра:
currentValue,currentKey-
Текущий элемент из
Set. Т.к. вSetнет ключей, в каждом будет лежать value. set-
Сам объект
Setдля которого был вызванforEach().
thisArg-
Значение, используемое как
thisв ходе выполненияcallback.
Возвращаемое значение
Описание
Метод forEach() выполняет callback по одному разу для каждого значения, которое находится в объекте Set. Функция не будет выполняться для значений, которые были удалены. Тем не менее функция выполнится с элементами, значение которых undefined.
callback вызывается с тремя аргументами:
- значение элемента
- ключ элемента
Setобъект обхода
В объектах типа Set нет ключей, поэтому оба первых аргумента принимают значение содержащееся в Set. Это делает метод forEach() для объекта Set совместимым с методами forEach() других объектов, таких как Map (en-US) и Array.
Если аргумент thisArg был передан в forEach(), то он будет передан в callback , во время исполнения, для использование его в качестве this. Иначе в this будет хранится значение undefined. Значение this используемое в callback определено согласно с обычными правилами определения this используемого функцией
Каждое значение используется только один раз, исключая те случаи, когда оно было удалено и передобавлено до того, как forEach() завершился. callback не будет выполнена для элементов, которые были удалены до их использования. Новые значения, которые были добавлены до того как forEach() завершился будут использованы.
forEach() выполняет callback однажды для каждого элемента из объекта Set; Он не возвращает никакого значения.
Примеры
Содержимое объекта Set
Приведённый код показывает состояние каждого элемента в объекте Set:
js
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 Language Specification # sec-set.prototype.foreach |
Совместимость в браузерах
BCD tables only load in the browser