Il metodo JavaScript Array flatMap () mappa prima ogni elemento utilizzando una funzione di mappatura, quindi lo appiattisce in un nuovo array.
La sintassi del flatMap()
metodo è:
arr.flatMap(callback(currentValue),thisArg)
Qui, arr è un array.
parametri flatMap ()
Il flatMap()
metodo comprende:
- callback - La funzione da eseguire inizialmente su ogni elemento dell'array. Comprende:
- currentValue - L'elemento corrente passato dall'array.
- thisArg (opzionale) - Valore da utilizzare come
this
durante l'esecuzionecallback
.
Valore restituito da flatMap ()
- Restituisce un nuovo array dopo aver mappato ogni elemento usando
callback
e appiattendolo a una profondità di 1 .
Note :
- Il
flatMap()
metodo non modifica l'array originale. - Il
flatMap()
metodo è equivalente aarray.map().flat()
.
Esempio: utilizzo del metodo 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 )
Produzione
(1, 4, 9, 16, 25) ((1), (4), (9), (16), (25)) (1, 4, 9, 16, 25) (1, 1, 2, 2, 3, 3)
Letture consigliate: JavaScript Array flat ()