Menu

gitpiper

partitionBy javascript Code Snippet in 2022

arrayobjectadvanced

Last Updated: 28 December 2022

Applies fn to each value in arr, splitting it each time the provided function returns a new value.

  • Use Array.prototype.reduce() with an accumulator object that will hold the resulting array and the last value returned from fn.
  • Use Array.prototype.push() to add each value in arr to the appropriate partition in the accumulator array.
const partitionBy = (arr, fn) => arr.reduce( ({ res, last }, v, i, a) => { const next = fn(v, i, a); if (next !== last) res.push([v]); else res[res.length - 1].push(v); return { res, last: next }; }, { res: [] } ).res;
const numbers = [1, 1, 3, 3, 4, 5, 5, 5]; partitionBy(numbers, n => n % 2 === 0); // [[1, 1, 3, 3], [4], [5, 5, 5]] partitionBy(numbers, n => n); // [[1, 1], [3, 3], [4], [5, 5, 5]]

javascript snippet similar to partitionBy For You in December 2022

Subscribe to our Newsletter

Subscribe to get resources directly to your inbox. You won't receive any spam! ✌️

© 2022 GitPiper. All rights reserved

Rackpiper Technology Inc

Company

About UsBlogContact

Subscribe to our Newsletter

Subscribe to get resources directly to your inbox. You won't receive any spam! ✌️