117 of 264 menu

flatMapメソッド

メソッド flatMap は、 元の配列の各要素にメソッドのパラメータで指定された コールバックが 適用された後に作成される新しい配列を返します。 一見すると flatMap メソッドは map メソッドに似ていますが、主な違いは 常に一次元配列を返す点です。

構文

let newArray = 配列.flatMap(関数);

メソッド flatMap を使って 新しい配列を取得してみましょう:

let arr = ['a', 'b', 'c']; let res = arr.flatMap(function(elem) { return elem + '!'; }); console.log(res);

コード実行結果:

['a!', 'b!', 'c!']

数値で構成された元の配列から 新しい配列を取得してみましょう:

let arr = [1, 2, 3, 4, 5]; let res = arr.flatMap(function(elem) { return elem + 2; }); console.log(res);

コード実行結果:

[3, 4, 5, 6, 7]

最初のネストレベルを持つ配列に メソッド flatMap を適用してみましょう:

let arr = [1, 2, 3, [4, 5]]; let res = arr.flatMap(function getElem(elem){ return elem + 2; }); console.log(res);

コードを実行すると、 関数の条件がサブ配列に適用され、 それを一つの要素として扱ったことがわかります。 したがって、このメソッドをネストされた配列で呼び出すことは 意味がありません:

[3, 4, 5, '4,52']

ネストレベルを気にせず、 配列全体を平坦化したい場合は、 パラメータ Infinity を使用します:

let arr = ['a', 'b', ['c', 'd', ['e', 'f', ['g', 'h', ['i']]]]]; let res = arr.flatMap(Infinity); console.log(res);

コード実行結果:

[ 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i' ]

配列に2つのメソッド、 flatMapmap を適用してみましょう。 両メソッドのパラメータには、 配列を二次元にする関数を指定します:

let arr = [1, 2, 3, 4, 5, 6]; let res1 = arr.map(elem => [elem * 3]); let res2 = arr.flatMap(elem => [elem * 3]); console.log('mapメソッド', res1); console.log('flatMapメソッド', res2);

コード実行結果:

'mapメソッド' [[3], [6], [9], [12], [15], [18]] 'flatMapメソッド' [3, 6, 9, 12, 15, 18]

関連項目

  • サブ配列から配列を返すメソッド flat
日本語
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItalianoქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
当サイトでは、サイトの動作、分析、パーソナライゼーションのためにクッキーを使用しています。 データ処理はプライバシーポリシーに従って行われます。
すべて受け入れる 設定 拒否