mirror of
https://github.com/toss/es-toolkit.git
synced 2024-12-03 13:53:50 +03:00
ead6a8290e
* feat: add meanBy * chore: fix typo * Update benchmarks/meanBy.bench.ts --------- Co-authored-by: Sojin Park <raon0211@gmail.com>
28 lines
679 B
Markdown
28 lines
679 B
Markdown
# meanBy
|
|
|
|
Calculates the average of an array of numbers when applying the `getValue` function to each element.
|
|
|
|
If the array is empty, this function returns `NaN`.
|
|
|
|
## Signature
|
|
|
|
```typescript
|
|
export function meanBy<T>(items: T[], getValue: (element: T) => number): number;
|
|
```
|
|
|
|
### Parameters
|
|
|
|
- `items` (`T[]`): An array to calculate the average.
|
|
- `getValue` (`(item: T) => number`): A function that selects a numeric value from each element.
|
|
|
|
### Returns
|
|
|
|
(`number`): The average of all the numbers as determined by the `getValue` function.
|
|
|
|
## Examples
|
|
|
|
```typescript
|
|
meanBy([{ a: 1 }, { a: 2 }, { a: 3 }], x => x.a); // Returns: 2
|
|
meanBy([], x => x.a); // Returns: NaN
|
|
```
|