es-toolkit
Version:
A state-of-the-art, high-performance JavaScript utility library with a small bundle size and strong type annotations.
37 lines (34 loc) • 1.14 kB
TypeScript
import { ListIteratee } from '../_internal/ListIteratee.js';
/**
* Creates a slice of array with elements taken from the beginning. Elements are taken until predicate
* returns falsey. The predicate is invoked with three arguments: (value, index, array).
*
* @template T
* @param {ArrayLike<T> | null | undefined} array - The array to query.
* @param {ListIteratee<T>} [predicate] - The function invoked per iteration.
* @returns {T[]} Returns the slice of array.
*
* @example
* const users = [
* { 'user': 'barney', 'active': false },
* { 'user': 'fred', 'active': false },
* { 'user': 'pebbles', 'active': true }
* ];
*
* takeWhile(users, function(o) { return !o.active; });
* // => objects for ['barney', 'fred']
*
* @example
* takeWhile(users, { 'user': 'barney', 'active': false });
* // => objects for ['barney']
*
* @example
* takeWhile(users, ['active', false]);
* // => objects for ['barney', 'fred']
*
* @example
* takeWhile(users, 'active');
* // => []
*/
declare function takeWhile<T>(array: ArrayLike<T> | null | undefined, predicate?: ListIteratee<T>): T[];
export { takeWhile };