JavaScript Array flatMap ()

Metoda JavaScript Array flatMap () najpierw odwzorowuje każdy element za pomocą funkcji mapującej, a następnie spłaszcza go do nowej tablicy.

Składnia flatMap()metody to:

 arr.flatMap(callback(currentValue),thisArg)

Tutaj arr jest tablicą.

flatMap () Parametry

flatMap()Sposób odbywa się:

  • callback - funkcja do początkowego wykonania na każdym elemencie tablicy. Zajmuje:
    • currentValue - bieżący element przekazywany z tablicy.
  • thisArg (opcjonalne) - wartość używana thispodczas wykonywania callback.

Wartość zwracana z flatMap ()

  • Zwraca nową tablicę po zmapowaniu każdego elementu przy użyciu callbacki spłaszczeniu do głębokości 1 .

Uwagi :

  • flatMap()Sposób nie zmienia oryginalnej tablicy.
  • flatMap()Metoda jest równoważna array.map().flat().

Przykład: użycie metody flatMap ()

 const arr1 = (1, 2, 3, 4, 5); const newArr1 = arr1.flatMap((x) => (x ** 2)); console.log(newArr1); // ( 1, 2, 3, 4, 5 ) // can also be done as const intermediate = arr1.map((x) => (x ** 2)); console.log(intermediate); // ( ( 1 ), ( 4 ), ( 9 ), ( 16 ), ( 25 ) ) const newArr2 = intermediate.flat(); console.log(newArr2); // ( 1, 4, 9, 16, 25 ) const numbers = (1, 2, 3, 4, 5, 6, 7); // remove odd and split even element to two half elements function func(n) ( if (n % 2 === 0) ( return (n / 2, n / 2); ) else ( return (); ) ) const newArr3 = numbers.flatMap(func); console.log(newArr3); // ( 1, 1, 2, 2, 3, 3 )

Wynik

 (1, 4, 9, 16, 25) ((1), (4), (9), (16), (25)) (1, 4, 9, 16, 25) (1, 1, 2, 2, 3, 3)

Zalecana lektura: JavaScript Array flat ()

Interesujące artykuły...