function stable
Emits a value from the source Observable only after a particular time span has passed without another source emission.
debounceTime<T>(dueTime: number, scheduler: SchedulerLike = async): MonoTypeOperatorFunction<T>| dueTime |  The timeout duration in milliseconds (or the time unit determined internally by the optional  | 
| scheduler |  Optional. Default is   The  | 
MonoTypeOperatorFunction<T>: An Observable that delays the emissions of the source Observable by the specified dueTime, and may drop some values if they occur too frequently.
It's like delay, but passes only the most recent value from each burst of emissions.
debounceTime delays values emitted by the source Observable, but drops previous pending delayed emissions if a new value arrives on the source Observable. This operator keeps track of the most recent value from the source Observable, and emits that only when dueTime enough time has passed without any other value appearing on the source Observable. If a new value appears before dueTime silence occurs, the previous value will be dropped and will not be emitted on the output Observable.
This is a rate-limiting operator, because it is impossible for more than one value to be emitted in any time window of duration dueTime, but it is also a delay-like operator since output emissions do not occur at the same time as they did on the source Observable. Optionally takes a SchedulerLike for managing timers.
Emit the most recent click after a burst of clicks
import { fromEvent } from 'rxjs';
import { debounceTime } from 'rxjs/operators';
const clicks = fromEvent(document, 'click');
const result = clicks.pipe(debounceTime(1000));
result.subscribe(x => console.log(x));   
    © 2015–2018 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/debounceTime