ReadableBase
The EventEmitter class is defined and exposed by the node:events module:
All EventEmitters emit the event 'newListener' when new listeners are
added and 'removeListener' when existing listeners are removed.
It supports the following option:
Since
v0.1.26
Implements
Properties
closedbooleanRequiredtrue after 'close' has been emitted.destroyedbooleanRequiredtrue after readable.destroy() has been called.readablebooleanRequiredtrue if it is safe to call readable.read(), which means the stream has not been destroyed or emitted 'error' or 'end'.readableAbortedbooleanRequired'end'.readableDidReadbooleanRequired'data' has been emitted.encoding of a given Readable stream. The encodingproperty can be set using the readable.setEncoding() method.readableEndedbooleanRequiredtrue when 'end' event is emitted.readableFlowingnull | booleanRequiredReadable stream as described in the Three states section.readableHighWaterMarknumberRequiredhighWaterMark passed when creating this Readable.readableLengthnumberRequiredhighWaterMark.readableObjectModebooleanRequiredobjectMode of a given Readable stream.Symbol.for('nodejs.rejection') See how to write a custom rejection handler.captureRejectionsbooleanRequireddefaultMaxListenersnumberRequired10 listeners can be registered for any single event. This limit can be changed for individual EventEmitter instances using the emitter.setMaxListeners(n) method. To change the default for _all_EventEmitter instances, the events.defaultMaxListenersproperty can be used. If this value is not a positive number, a RangeErroris thrown. Take caution when setting the events.defaultMaxListeners because the change affects _all_EventEmitter instances, including those created before the change is made. However, calling emitter.setMaxListeners(n) still has precedence over events.defaultMaxListeners. This is not a hard limit. The EventEmitter instance will allow more listeners to be added but will output a trace warning to stderr indicating that a "possible EventEmitter memory leak" has been detected. For any singleEventEmitter, the emitter.getMaxListeners() and emitter.setMaxListeners()methods can be used to temporarily avoid this warning: js import { EventEmitter } from 'node:events'; const emitter = new EventEmitter(); emitter.setMaxListeners(emitter.getMaxListeners() + 1); emitter.once('event', () => { // do stuff emitter.setMaxListeners(Math.max(emitter.getMaxListeners() - 1, 0)); }); The --trace-warnings command-line flag can be used to display the stack trace for such warnings. The emitted warning can be inspected with process.on('warning') and will have the additional emitter, type, and count properties, referring to the event emitter instance, the event's name and the number of attached listeners, respectively. Its name property is set to 'MaxListenersExceededWarning'.'error'events. Listeners installed using this symbol are called before the regular'error' listeners are called. Installing a listener using this symbol does not change the behavior once an'error' event is emitted. Therefore, the process will still crash if no regular 'error' listener is installed.Methods
[asyncDispose]
Calls readable.destroy() with an AbortError and returns a promise that fulfills when the stream is finished.
Returns
PromisePromise<void>RequiredSince
v20.4.0
[asyncIterator]
Returns
[captureRejectionSymbol]
Parameters
Returns
voidvoid_construct
Parameters
Returns
voidvoid_destroy
Parameters
Returns
voidvoid_read
Parameters
sizenumberRequiredReturns
voidvoidaddListener
**addListener**(event, listener): [ReadableBase](/references/js-client/internal/classes/internal.ReadableBase)
Event emitter The defined events on documents including:
- close
- data
- end
- error
- pause
- readable
- resume
Parameters
event"close"Requiredlistener() => voidRequiredReturns
**addListener**(event, listener): [ReadableBase](/references/js-client/internal/classes/internal.ReadableBase)
Parameters
event"data"Requiredlistener(chunk: any) => voidRequiredReturns
**addListener**(event, listener): [ReadableBase](/references/js-client/internal/classes/internal.ReadableBase)
Parameters
event"end"Requiredlistener() => voidRequiredReturns
**addListener**(event, listener): [ReadableBase](/references/js-client/internal/classes/internal.ReadableBase)
Parameters
event"error"RequiredReturns
**addListener**(event, listener): [ReadableBase](/references/js-client/internal/classes/internal.ReadableBase)
Parameters
event"pause"Requiredlistener() => voidRequiredReturns
**addListener**(event, listener): [ReadableBase](/references/js-client/internal/classes/internal.ReadableBase)
Parameters
event"readable"Requiredlistener() => voidRequiredReturns
**addListener**(event, listener): [ReadableBase](/references/js-client/internal/classes/internal.ReadableBase)
Parameters
event"resume"Requiredlistener() => voidRequiredReturns
**addListener**(event, listener): [ReadableBase](/references/js-client/internal/classes/internal.ReadableBase)
Parameters
eventstring | symbolRequiredlistener(...args: any[]) => voidRequiredReturns
asIndexedPairs
This method returns a new stream with chunks of the underlying stream paired with a counter
in the form [index, chunk]. The first index value is 0 and it increases by 1 for each chunk produced.
Parameters
optionsPick<ArrayOptions, "signal">Returns
Since
v17.5.0
compose
Parameters
optionsobjectoptions.signalAbortSignalRequiredReturns
destroy
Destroy the stream. Optionally emit an 'error' event, and emit a 'close'event (unless emitClose is set to false). After this call, the readable
stream will release any internal resources and subsequent calls to push()will be ignored.
Once destroy() has been called any further calls will be a no-op and no
further errors except from _destroy() may be emitted as 'error'.
Implementors should not override this method, but instead implement readable._destroy().
Parameters
errorError'error' eventReturns
Since
v8.0.0
drop
This method returns a new stream with the first limit chunks dropped from the start.
Parameters
limitnumberRequiredoptionsPick<ArrayOptions, "signal">Returns
Since
v17.5.0
emit
**emit**(event): boolean
Synchronously calls each of the listeners registered for the event namedeventName, in the order they were registered, passing the supplied arguments
to each.
Returns true if the event had listeners, false otherwise.
import { EventEmitter } from 'node:events';
const myEmitter = new EventEmitter();
// First listener
myEmitter.on('event', function firstListener() {
console.log('Helloooo! first listener');
});
// Second listener
myEmitter.on('event', function secondListener(arg1, arg2) {
console.log(`event with parameters ${arg1}, ${arg2} in second listener`);
});
// Third listener
myEmitter.on('event', function thirdListener(...args) {
const parameters = args.join(', ');
console.log(`event with parameters ${parameters} in third listener`);
});
console.log(myEmitter.listeners('event'));
myEmitter.emit('event', 1, 2, 3, 4, 5);
// Prints:
// [
// [Function: firstListener],
// [Function: secondListener],
// [Function: thirdListener]
// ]
// Helloooo! first listener
// event with parameters 1, 2 in second listener
// event with parameters 1, 2, 3, 4, 5 in third listener
Parameters
event"close"RequiredReturns
booleanbooleanSince
v0.1.26
**emit**(event, chunk): boolean
Parameters
event"data"RequiredchunkanyRequiredReturns
booleanboolean**emit**(event): boolean
Parameters
event"end"RequiredReturns
booleanboolean**emit**(event, err): boolean
Parameters
event"error"RequiredReturns
booleanboolean**emit**(event): boolean
Parameters
event"pause"RequiredReturns
booleanboolean**emit**(event): boolean
Parameters
event"readable"RequiredReturns
booleanboolean**emit**(event): boolean
Parameters
event"resume"RequiredReturns
booleanboolean**emit**(event, ...args): boolean
Parameters
eventstring | symbolRequiredargsany[]RequiredReturns
booleanbooleaneventNames
Returns an array listing the events for which the emitter has registered
listeners. The values in the array are strings or Symbols.
Returns
(string \| symbol)[](string | symbol)[]RequiredSince
v6.0.0
every
This method is similar to Array.prototype.every and calls fn on each chunk in the stream
to check if all awaited return values are truthy value for fn. Once an fn call on a chunk
awaited return value is falsy, the stream is destroyed and the promise is fulfilled with false.
If all of the fn calls on the chunks return a truthy value, the promise is fulfilled with true.
Parameters
optionsArrayOptionsReturns
PromisePromise<boolean>Requiredtrue if fn returned a truthy value for every one of the chunks.Since
v17.5.0
filter
This method allows filtering the stream. For each chunk in the stream the fn function will be called
and if it returns a truthy value, the chunk will be passed to the result stream.
If the fn function returns a promise - that promise will be awaited.
Parameters
optionsArrayOptionsReturns
Since
v17.4.0, v16.14.0
find
**find**<TypeParameter T>(fn, options?): Promise<undefined \| T>
This method is similar to Array.prototype.find and calls fn on each chunk in the stream
to find a chunk with a truthy value for fn. Once an fn call's awaited return value is truthy,
the stream is destroyed and the promise is fulfilled with value for which fn returned a truthy value.
If all of the fn calls on the chunks return a falsy value, the promise is fulfilled with undefined.
Parameters
optionsArrayOptionsReturns
PromisePromise<undefined | T>Requiredundefined if no element was found.Since
v17.5.0
**find**(fn, options?): Promise<any>
Parameters
optionsArrayOptionsReturns
PromisePromise<any>RequiredflatMap
This method returns a new stream by applying the given callback to each chunk of the stream and then flattening the result.
It is possible to return a stream or another iterable or async iterable from fn and the result streams will be merged (flattened) into the returned stream.
Parameters
optionsArrayOptionsReturns
Since
v17.5.0
forEach
This method allows iterating a stream. For each chunk in the stream the fn function will be called.
If the fn function returns a promise - that promise will be awaited.
This method is different from for await...of loops in that it can optionally process chunks concurrently.
In addition, a forEach iteration can only be stopped by having passed a signal option
and aborting the related AbortController while for await...of can be stopped with break or return.
In either case the stream will be destroyed.
This method is different from listening to the 'data' event in that it uses the readable event
in the underlying machinary and can limit the number of concurrent fn calls.
Parameters
optionsArrayOptionsReturns
PromisePromise<void>RequiredSince
v17.5.0
getMaxListeners
Returns the current max listener value for the EventEmitter which is either
set by emitter.setMaxListeners(n) or defaults to defaultMaxListeners.
Returns
numbernumberSince
v1.0.0
isPaused
The readable.isPaused() method returns the current operating state of theReadable. This is used primarily by the mechanism that underlies thereadable.pipe() method. In most
typical cases, there will be no reason to
use this method directly.
Returns
booleanbooleanSince
v0.11.14