--- title: Map.prototype.forEach() slug: Web/JavaScript/Reference/Global_Objects/Map/forEach tags: - ECMAScript 2015 - JavaScript - Map - Method - Prototype - Reference translation_of: Web/JavaScript/Reference/Global_Objects/Map/forEach original_slug: Web/JavaScript/Reference/Global_Objects/Map/forEach browser-compat: javascript.builtins.Map.forEach ---
forEach()
方法按照插入顺序依次对 Map
中每个键/值对执行一次给定的函数
myMap.forEach(callback([value][,key][,map])[, thisArg])
callback
myMap
中每个元素所要执行的函数。它具有如下的参数
value
{{Optional_Inline}}key
{{Optional_Inline}}map
{{Optional_Inline}}myMap
)。thisArg
{{Optional_Inline}}callback
执行中使用的 this
的值。{{jsxref("undefined")}}.
forEach
方法会对map中每个真实存在的键执行一次给定的 callback
函数。它不会对被删除的键执行函数。然而,它会对每个值为 undefined
的键执行函数。
callback
接收三个参数:
value
key
Map
对象如果 forEach
中含有 thisArg
参数,那么每次 callback
被调用时,都会被用作 this
的值。否则,undefined
将会被用作 this
的值。按照函数观察到 this
的常用规则,callback
函数最终可观察到 this
值。
每个值只被访问一次,除非它被删除了或者在 forEach
结束前被改变了。callback
不会对在被访问前就删除的元素执行。在 forEach
结束前被添加的元素将会被访问。
forEach
会对 Map
对象中的每个元素执行一次 callback
。它不会返回值。
Map
对象中的内容以下的代码在每行中打印一个 Map
对象中的元素
function logMapElements(value, key, map) { console.log(`map.get('${key}') = ${value}`) } new Map([['foo', 3], ['bar', {}], ['baz', undefined]]).forEach(logMapElements) // logs: // "map.get('foo') = 3" // "map.get('bar') = [object Object]" // "map.get('baz') = undefined"
规范 |
---|
{{SpecName('ESDraft', '#sec-map.prototype.foreach', 'Map.prototype.forEach')}} |
{{Compat("javascript.builtins.Map.forEach")}}