Files
30-seconds-of-code/snippets/js/s/ungroup-array-elements-based-on-function.md
Angelos Chalaris 9d032ce05e Rename js snippets
2023-05-19 20:23:47 +03:00

1.0 KiB

title, type, language, tags, cover, dateModified
title type language tags cover dateModified
Ungroup array elements based on function snippet javascript
array
rustic-cup 2022-01-23T13:18:50+03:00

Creates an array of elements, ungrouping the elements in an array produced by zip and applying the provided function.

  • Use Math.max() and the spread operator (...) to get the longest subarray in the array, Array.prototype.map() to make each element an array.
  • Use Array.prototype.reduce() and Array.prototype.forEach() to map grouped values to individual arrays.
  • Use Array.prototype.map() and the spread operator (...) to apply fn to each individual group of elements.
const unzipWith = (arr, fn) =>
  arr
    .reduce(
      (acc, val) => (val.forEach((v, i) => acc[i].push(v)), acc),
      Array.from({
        length: Math.max(...arr.map(x => x.length))
      }).map(x => [])
    )
    .map(val => fn(...val));
unzipWith(
  [
    [1, 10, 100],
    [2, 20, 200],
  ],
  (...args) => args.reduce((acc, v) => acc + v, 0)
);
// [3, 30, 300]