throttle method
Reduces the rate that events are emitted to at most once per duration
.
No events will ever be emitted within duration
of another event on the
result stream.
If this stream is a broadcast stream, the result will be as well.
Errors are forwarded immediately.
If trailing
is false
, source events emitted during the duration
period following a result event are discarded.
The result stream will not emit an event until this stream emits an event
following the throttled period.
If this stream is consistently emitting events with less than
duration
between events, the time between events on the result stream
may still be more than duration
.
The result stream will close immediately when this stream closes.
If trailing
is true
, the latest source event emitted during the
duration
period following an result event is held and emitted following
the period.
If this stream is consistently emitting events with less than duration
between events, the time between events on the result stream will be
duration
.
If this stream closes the result stream will wait to emit a pending event
before closing.
For example:
source.throttle(Duration(seconds: 6));
source: 1-2-3---4-5-6---7-8-|
result: 1-------4-------7---|
source.throttle(Duration(seconds: 6), trailing: true);
source: 1-2-3---4-5----6--|
result: 1-----3-----5-----6|
source.throttle(Duration(seconds: 6), trailing: true);
source: 1-2-----------3|
result: 1-----2-------3|
See also:
- audit, which emits the most recent event at the end of the period.
Compared to
audit
,throttle
will not introduce delay to forwarded elements, except for thetrailing
events. - debounce, which uses inter-event spacing instead of a fixed period
from the first event in a window. Compared to
debouce
,throttle
cannot be starved by having events emitted continuously withinduration
.
Implementation
Stream<T> throttle(Duration duration, {bool trailing = false}) =>
trailing ? _throttleTrailing(duration) : _throttle(duration);