Remeda functions are not necessarily drop-in replacements for the listed Lodash and Ramda functions. Just as the Lodash function may behave differently than the Ramda equivalent, the Remeda function may also behave differently from either or both. Be sure to consult each library's documentation when migrating.
Some lodash and ramda functions don't have a Remeda equivalent, but can be easily replaced with a one-liner in TypeScript. Some of the most common are listed below.
TypeScript one-liners are not necessarily drop-in replacements that provide the exact functionality of the listed Lodash and Ramda functions. Be sure to consult each library's documentation and to check what features you are relying on when migrating.
Remeda | Lodash | Ramda |
---|---|---|
(arr, val) => [...arr, val] |
append |
|
a?.b?.c |
path |
|
n => a[n] |
nth |
nth |
R.constant(undefined) |
noop |
|
R.filter(R.isIncludedIn(other)) |
intersection |
intersection |
R.filter(R.isNot(fn)) |
reject |
reject |
R.filter(R.isNot(R.isIncludedIn(other))) |
difference |
difference |
R.filter(R.isTruthy) |
compact |
|
R.firstBy([fn, "desc"]) |
maxBy |
maxBy |
R.firstBy([R.identity, "desc"]) |
max |
max |
R.firstBy(fn) |
minBy |
minBy |
R.firstBy(R.identity) |
min |
min |
R.fromEntries.strict(R.zip(keys, values)) |
zipObj |
zipObj |
str => str.split(/\s+/) |
words |
|
x => x.a ?? defaultValue |
propOr |
|
x => x.a === value |
propEq |