Set.prototype.forEach()
forEach() 方法对 Set 对象中的每个值按插入顺序执行一次提供的函数。
尝试一下
语法
js
forEach(callbackFn)
forEach(callbackFn, thisArg)
参数
callback-
为集合中每个元素执行的回调函数,该函数接收三个参数:
value、key-
Set中正在处理的当前元素。因为Set中没有键,所以value会被共同传递给这两个参数。 set-
调用
forEach()的Set对象。
thisArg-
值在执行
callbackFn时作为this使用。
返回值
描述
forEach() 方法对 Set 对象中实际存在的每个值执行一次提供的 callback。对于已删除的值,不会调用它。但是,它会对存在但值为 undefined 的值执行。
callback 被调用时带有三个参数:
- 元素的值
- 元素的键
- 被遍历的
Set
但是由于 Set 对象中没有键(key),所以前两个参数都是 Set 中元素的值(value),之所以这样设计回调函数是为了和 Map 以及 Array 的 forEach() 函数用法保持一致。
如果提供了一个 thisArg 参数给 forEach 函数,则参数将会作为回调函数中的 this值。否则 this 值为 undefined。回调函数中 this 的绑定是根据函数被调用时通用的 this 绑定规则来决定的。
每个值都访问一次,除非在 forEach() 完成之前删除并重新添加它。在访问之前删除的值不会调用 callback。在 forEach() 完成之前添加的新值将被访问。
forEach() 对 Set 对象中的每个元素执行一次 callback 函数;它没有返回值。
示例
输出集合对象的内容
以下代码依次打印 Set 对象的元素:
js
function logSetElements(value1, value2, set) {
console.log(`s[${value}] = ${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