rxjs / 7.5.5 / api / operators / max.html /

max

function stable operator

The Max 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 largest value.

max<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 largest value.

Description

max marble diagram

Examples

Get the maximal value of a series of numbers

import { of, max } from 'rxjs';

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

// Outputs
// 8

Use a comparer function to get the maximal item

import { of, max } from 'rxjs';

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

// Outputs
// 'Beer'

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/max