Skip to content

filter (Lodash Compatibility) ​

Use Array.prototype.filter()

This filter function operates slowly due to complex object processing, support for various condition formats, etc.

Instead, use the faster and more modern Array.prototype.filter().

Creates a new array with elements that satisfy the given condition.

typescript
const result = filter(collection, predicate);

Reference ​

filter(collection, predicate) ​

Use filter when you want to filter out only elements that satisfy a specific condition from an array or object. The condition can be specified in various formats such as a function, partial object, property-value pair, property name, etc.

typescript
import { filter } from 'es-toolkit/compat';

// Using a test function
const numbers = [1, 2, 3, 4, 5];
filter(numbers, x => x % 2 === 0);
// Returns: [2, 4]

// Using a property name
const users = [
  { name: 'Alice', active: true },
  { name: 'Bob', active: false },
  { name: 'Charlie', active: true },
];
filter(users, 'active');
// Returns: [{ name: 'Alice', active: true }, { name: 'Charlie', active: true }]

// Using a partial object
filter(users, { active: true });
// Returns: [{ name: 'Alice', active: true }, { name: 'Charlie', active: true }]

// Using a property-value pair
filter(users, ['active', true]);
// Returns: [{ name: 'Alice', active: true }, { name: 'Charlie', active: true }]

It works the same way for objects, returning an array of values that satisfy the condition.

typescript
import { filter } from 'es-toolkit/compat';

const scores = { math: 90, english: 75, science: 85 };
filter(scores, score => score >= 80);
// Returns: [90, 85]

null or undefined are treated as empty arrays.

typescript
import { filter } from 'es-toolkit/compat';

filter(null, x => x > 0);
// Returns: []

filter(undefined, x => x > 0);
// Returns: []

Parameters ​

  • collection (ArrayLike<T> | Record<string, unknown> | null | undefined): The array or object to filter.
  • predicate (((item: T, index: number, collection: any) => unknown) | Partial<T> | [keyof T, unknown] | PropertyKey): The filtering condition. Can use a function, partial object, property-value pair, or property name.

Returns ​

(T[]): Returns a new array consisting of elements that satisfy the condition.

Released under the MIT License.