rxjs / 7.5.5 / api / operators / min.html /

min

function stable operator

The Min operator operates on an Observable that emits numbers (or items that can be compared with a provided function), and when source Observable completes it emits a single item: the item with the smallest value.

min<T>(comparer?: (x: T, y: T) => number): MonoTypeOperatorFunction<T>

Parameters

comparer (x: T, y: T) => number

Optional. Default is undefined.

Optional comparer function that it will use instead of its default to compare the value of two items.

Returns

MonoTypeOperatorFunction<T>: A function that returns an Observable that emits item with the smallest value.

Description

min marble diagram

Examples

Get the minimal value of a series of numbers

import { of, min } from 'rxjs';

of(5, 4, 7, 2, 8)
  .pipe(min())
  .subscribe(x => console.log(x));

// Outputs
// 2

Use a comparer function to get the minimal item

import { of, min } from 'rxjs';

of(
  { age: 7, name: 'Foo' },
  { age: 5, name: 'Bar' },
  { age: 9, name: 'Beer' }
).pipe(
  min((a, b) => a.age < b.age ? -1 : 1)
)
.subscribe(x => console.log(x.name));

// Outputs
// 'Bar'

See Also

© 2015–2022 Google, Inc., Netflix, Inc., Microsoft Corp. and contributors.
Code licensed under an Apache-2.0 License. Documentation licensed under CC BY 4.0.
https://rxjs.dev/api/operators/min