@newdash/newdash
Version:
javascript/typescript utility library
42 lines (41 loc) • 1.32 kB
TypeScript
import type { Predicate } from "./types";
/**
* Iterates over elements of `collection`, returning an array of all elements
* `predicate` returns truthy for. The predicate is invoked with three
* arguments: (value, index|key, collection).
*
* **Note:** Unlike `remove`, this method returns a new array.
*
* @since 5.0.0
* @category Collection
* @param collection The collection to iterate over.
* @param predicate The function invoked per iteration.
* @returns Returns the new filtered array.
* @see reject
* @example
*
* ```js
* var users = [
* { 'user': 'barney', 'age': 36, 'active': true },
* { 'user': 'fred', 'age': 40, 'active': false }
* ];
*
* filter(users, function(o) { return !o.active; });
* // => objects for ['fred']
*
* // The `matches` iteratee shorthand.
* filter(users, { 'age': 36, 'active': true });
* // => objects for ['barney']
*
* // The `matchesProperty` iteratee shorthand.
* filter(users, ['active', false]);
* // => objects for ['fred']
*
* // The `property` iteratee shorthand.
* filter(users, 'active');
* // => objects for ['barney']
* ```
*/
export declare function filter<T>(collection: Array<T>, predicate?: Predicate<T>): Array<T>;
export declare function filter<T>(collection: Array<T>, predicate?: any): Array<T>;
export default filter;