LendAndRegret/node_modules/es-toolkit/dist/compat/array/countBy.d.mts
2026-05-02 17:27:43 +08:00

20 lines
947 B
TypeScript

import { ValueIteratee } from '../_internal/ValueIteratee.mjs';
/**
* Creates an object composed of keys generated from the results of running each element of collection through
* iteratee. The corresponding value of each key is the number of times the key was returned by iteratee. The
* iteratee is invoked with one argument: (value).
*
* @param collection The collection to iterate over.
* @param iteratee The function invoked per iteration.
* @return Returns the composed aggregate object.
*
* @example
* countBy([6.1, 4.2, 6.3], Math.floor); // => { '4': 1, '6': 2 }
* countBy(['one', 'two', 'three'], 'length'); // => { '3': 2, '5': 1 }
*/
declare function countBy<T>(collection: ArrayLike<T> | null | undefined, iteratee?: ValueIteratee<T>): Record<string, number>;
declare function countBy<T extends object>(collection: T | null | undefined, iteratee?: ValueIteratee<T[keyof T]>): Record<string, number>;
export { countBy };