Readable class
- Extends
-
Stream
Construtores
| Readable(Readable |
Propriedades
| closed | É |
| destroyed | É |
| errored | Devolve erro se o fluxo tiver sido destruído com um erro. |
| readable | É |
| readable |
Devolve se o fluxo foi destruído ou cometeu erro antes de emitir |
| readable |
Devolve se |
| readable |
Getter para a propriedade |
| readable |
Torna-se |
| readable |
Esta propriedade reflete o estado atual de um |
| readable |
Devolve o valor de |
| readable |
Esta propriedade contém o número de bytes (ou objetos) na fila prontos para serem lidos. O valor fornece dados de introspeção relativamente ao estado do |
| readable |
Getter para a propriedade |
Métodos
| add |
|
| add |
|
| compose(Writable |
Este método também permite fornecer um Consulte |
| destroy(Error) | Destrua o fluxo. Opcionalmente, emita um Uma vez Os implementadores não devem sobrepor este método, mas sim implementar |
| drop(number, Abortable) | Este método devolve um novo fluxo com os primeiros blocos de limite eliminados desde o início. |
| emit(string | symbol, any[]) | |
| emit<E>(E, Readable |
|
| every((data: any, options?: Abortable) => boolean | Promise<boolean>, Pick<Readable |
Este método é semelhante a |
| filter((data: any, options?: Abortable) => boolean | Promise<boolean>, Readable |
Este método permite filtrar o fluxo. Para cada chunk no fluxo, a função fn será chamada e, se devolver um valor truthy, o chunk será passado para o fluxo resultante.
Se a função fn devolver uma promessa – essa promessa será |
| find((data: any, options?: Abortable) => boolean | Promise<boolean>, Pick<Readable |
|
| find<T>((data: any, options?: Abortable) => data, Pick<Readable |
Este método é semelhante a |
| flat |
Este método devolve um novo fluxo aplicando o callback dado a cada bloco do fluxo e depois achatando o resultado. É possível devolver um fluxo ou outro iterável iterável ou assíncrono a partir do fn e os fluxos resultantes serão fundidos (achatados) no fluxo devolvido. |
| for |
Este método permite iterar um fluxo. Para cada bloco no fluxo, a função fn será chamada.
Se a função fn devolver uma promessa – essa promessa será Este método é diferente dos Este método difere de ouvir o |
| from(Iterable<any> | Async |
Um método utilitário para criar Fluxos Legíveis a partir de iteradores. |
| from |
Um método utilitário para criar um |
| is |
Devolve se a transmissão foi lida ou cancelada. |
| is |
O
|
| iterator(Readable |
O iterador criado por este método dá aos utilizadores a opção de cancelar a destruição do fluxo se o |
| listener |
|
| listener |
|
| listeners(string | symbol) | |
| listeners<E>(E) | |
| map((data: any, options?: Abortable) => any, Readable |
Este método permite mapear sobre o riacho. A função fn será chamada para cada bloco do fluxo.
Se a função fn devolver uma promessa - essa promessa será |
| off(string | symbol, (args: any[]) => void) | |
| off<E>(E, (args: Readable |
|
| on(string | symbol, (args: any[]) => void) | |
| on<E>(E, (args: Readable |
|
| once(string | symbol, (args: any[]) => void) | |
| once<E>(E, (args: Readable |
|
| pause() | O
O |
| prepend |
|
| prepend |
|
| prepend |
|
| prepend |
|
| push(any, Buffer |
|
| raw |
|
| raw |
|
| read(number) | O O argumento opcional Se o O O
Cada chamada para Portanto, para ler todo o conteúdo de um ficheiro a partir de um
Um Se o
A chamada de leitura após o |
| reduce<T>((previous: any, data: any, options?: Abortable) => T) | Este método chama fn em cada bloco do fluxo por ordem, passando-lhe o resultado do cálculo no elemento anterior. Devolve uma promessa do valor final da redução. Se não for fornecido valor inicial , o primeiro bloco do fluxo é usado como valor inicial.
Se o fluxo estiver vazio, a promessa é rejeitada com a A função redutora itera o fluxo elemento a elemento, o que significa que não existe parâmetro de concorrência nem paralelismo. Para realizar uma redução simultaneamente, pode extrair a função assíncrona do |
| reduce<T>((previous: T, data: any, options?: Abortable) => T, T, Abortable) | |
| remove |
|
| remove |
|
| remove |
|
| remove |
|
| resume() | O O
O |
| set |
O Por defeito, não é atribuída codificação e os dados do fluxo serão devolvidos como O
|
| some((data: any, options?: Abortable) => boolean | Promise<boolean>, Pick<Readable |
Este método é semelhante a |
| take(number, Abortable) | Este método devolve um novo fluxo com os primeiros blocos limite . |
| to |
Este método permite obter facilmente o conteúdo de um fluxo. Como este método lê todo o fluxo na memória, anula os benefícios dos fluxos. Destina-se à interoperabilidade e conveniência, não a principal forma de consumir streams. |
| to |
Um método utilitário para criar uma teia |
| unpipe(Writable |
O Se o Se o
|
| unshift(any, Buffer |
Passar O O Os programadores que usam
Ao contrário do push, |
| wrap(Readable |
Antes do Node.js 0.10, os fluxos não implementavam toda Ao usar uma biblioteca Node.js antiga que emite Raramente será necessário utilizá-lo
|
| [async |
Métodos Herdados
| event |
Retorna uma matriz listando os eventos para os quais o emissor registrou ouvintes.
|
| get |
Retorna o valor máximo de ouvinte atual para o |
| pipe<T>(T, Pipe |
|
| set |
Por padrão Retorna uma referência ao |
| [capture |
O
|
Detalhes do Construtor
Readable(ReadableOptions<Readable>)
Detalhes de Propriedade
closed
É true depois 'close' de ter sido emitido.
closed: boolean
Valor de Propriedade
boolean
destroyed
É true depois readable.destroy() de ter sido chamado.
destroyed: boolean
Valor de Propriedade
boolean
errored
Devolve erro se o fluxo tiver sido destruído com um erro.
errored: null | Error
Valor de Propriedade
null | Error
readable
É true se for seguro chamar read, o que significa que o fluxo não foi destruído ou emitido 'error' ou 'end'.
readable: boolean
Valor de Propriedade
boolean
readableAborted
Devolve se o fluxo foi destruído ou cometeu erro antes de emitir 'end'.
readableAborted: boolean
Valor de Propriedade
boolean
readableDidRead
Devolve se 'data' foi emitido.
readableDidRead: boolean
Valor de Propriedade
boolean
readableEncoding
Getter para a propriedade encoding de um dado Readable riacho. A encoding propriedade pode ser definida usando o método setEncoding .
readableEncoding: null | BufferEncoding
Valor de Propriedade
null | BufferEncoding
readableEnded
readableFlowing
Esta propriedade reflete o estado atual de um Readable curso de água conforme descrito na secção dos Três estados .
readableFlowing: null | boolean
Valor de Propriedade
null | boolean
readableHighWaterMark
Devolve o valor de highWaterMark passado ao criar este Readable.
readableHighWaterMark: number
Valor de Propriedade
number
readableLength
Esta propriedade contém o número de bytes (ou objetos) na fila prontos para serem lidos. O valor fornece dados de introspeção relativamente ao estado do highWaterMark.
readableLength: number
Valor de Propriedade
number
readableObjectMode
Getter para a propriedade objectMode de um dado Readable riacho.
readableObjectMode: boolean
Valor de Propriedade
boolean
Detalhes de Método
addListener(string | symbol, (args: any[]) => void)
function addListener(eventName: string | symbol, listener: (args: any[]) => void): Readable
Parâmetros
- eventName
-
string | symbol
- listener
-
(args: any[]) => void
Devoluções
addListener<E>(E, (args: ReadableEventMap[E]) => void)
function addListener<E>(eventName: E, listener: (args: ReadableEventMap[E]) => void): Readable
Parâmetros
- eventName
-
E
- listener
-
(args: ReadableEventMap[E]) => void
Devoluções
compose(WritableStream | WritableStream<any> | TransformStream<any, any> | (source: any) => void, Abortable)
import { Readable } from 'node:stream';
async function* splitToWords(source) {
for await (const chunk of source) {
const words = String(chunk).split(' ');
for (const word of words) {
yield word;
}
}
}
const wordsStream = Readable.from(['text passed through', 'composed stream']).compose(splitToWords);
const words = await wordsStream.toArray();
console.log(words); // prints ['text', 'passed', 'through', 'composed', 'stream']
readable.compose(s) é equivalente a stream.compose(readable, s).
Este método também permite fornecer um AbortSignal , que destruirá o fluxo composto quando abortado.
Consulte stream.compose(...streams) para obter mais informações.
function compose(stream: WritableStream | WritableStream<any> | TransformStream<any, any> | (source: any) => void, options?: Abortable): Duplex
Parâmetros
- stream
-
WritableStream | WritableStream<any> | TransformStream<any, any> | (source: any) => void
- options
-
Abortable
Devoluções
Duplex
um curso de água composto pelo fluxo stream.
destroy(Error)
Destrua o fluxo. Opcionalmente, emita um 'error' evento e emita um 'close' evento (a menos que emitClose esteja definido para false). Após esta chamada, o fluxo legível libertará quaisquer recursos internos e as chamadas subsequentes serão push() ignoradas.
Uma vez destroy() chamado, quaisquer chamadas adicionais serão no-op e nenhum erro adicional, exceto from, _destroy() poderá ser emitido como 'error'.
Os implementadores não devem sobrepor este método, mas sim implementar readable._destroy().
function destroy(error?: Error): Readable
Parâmetros
- error
-
Error
Erro que será transmitido como carga útil em 'error' caso de
Devoluções
drop(number, Abortable)
Este método devolve um novo fluxo com os primeiros blocos de limite eliminados desde o início.
function drop(limit: number, options?: Abortable): Readable
Parâmetros
- limit
-
number
O número de blocos a eliminar do legível.
- options
-
Abortable
Devoluções
um stream com blocos de limite descartados desde o início.
emit(string | symbol, any[])
function emit(eventName: string | symbol, args: any[]): boolean
Parâmetros
- eventName
-
string | symbol
- args
-
any[]
Devoluções
boolean
emit<E>(E, ReadableEventMap[E])
function emit<E>(eventName: E, args: ReadableEventMap[E]): boolean
Parâmetros
- eventName
-
E
- args
-
ReadableEventMap[E]
Devoluções
boolean
every((data: any, options?: Abortable) => boolean | Promise<boolean>, Pick<ReadableOperatorOptions, "signal" | "concurrency">)
Este método é semelhante a Array.prototype.every e chama fn em cada bloco do fluxo para verificar se todos os valores de retorno aguardados são valores truthy para fn. Uma vez que uma chamada fn num valor de retorno ed awaitchunk for falsa, o fluxo é destruído e a promessa é cumprida com false.
Se todas as chamadas fn nos chunks devolverem um valor truthy, a promessa é cumprida com true.
function every(fn: (data: any, options?: Abortable) => boolean | Promise<boolean>, options?: Pick<ReadableOperatorOptions, "signal" | "concurrency">): Promise<boolean>
Parâmetros
- fn
-
(data: any, options?: Abortable) => boolean | Promise<boolean>
uma função para chamar cada pedaço do fluxo. Assíncrono ou não.
- options
-
Pick<ReadableOperatorOptions, "signal" | "concurrency">
Devoluções
Promise<boolean>
Uma promessa que avalia se truea FN devolveu um valor de verdade para cada um dos blocos.
filter((data: any, options?: Abortable) => boolean | Promise<boolean>, ReadableOperatorOptions)
Este método permite filtrar o fluxo. Para cada chunk no fluxo, a função fn será chamada e, se devolver um valor truthy, o chunk será passado para o fluxo resultante.
Se a função fn devolver uma promessa – essa promessa será awaited.
function filter(fn: (data: any, options?: Abortable) => boolean | Promise<boolean>, options?: ReadableOperatorOptions): Readable
Parâmetros
- fn
-
(data: any, options?: Abortable) => boolean | Promise<boolean>
uma função para filtrar blocos do fluxo. Assíncrono ou não.
- options
-
ReadableOperatorOptions
Devoluções
um fluxo filtrado com o predicado fn.
find((data: any, options?: Abortable) => boolean | Promise<boolean>, Pick<ReadableOperatorOptions, "signal" | "concurrency">)
function find(fn: (data: any, options?: Abortable) => boolean | Promise<boolean>, options?: Pick<ReadableOperatorOptions, "signal" | "concurrency">): Promise<any>
Parâmetros
- fn
-
(data: any, options?: Abortable) => boolean | Promise<boolean>
- options
-
Pick<ReadableOperatorOptions, "signal" | "concurrency">
Devoluções
Promise<any>
find<T>((data: any, options?: Abortable) => data, Pick<ReadableOperatorOptions, "signal" | "concurrency">)
Este método é semelhante a Array.prototype.find e chama fn em cada bloco do fluxo para encontrar um bloco com um valor truthy para fn. Quando o valor de retorno aguardado de uma chamada fn é truthy, o stream é destruído e a promessa é cumprida com valor para o qual fn devolveu um valor truthy.
Se todas as chamadas fn nos chunks devolverem um valor falso, a promessa é cumprida com undefined.
function find<T>(fn: (data: any, options?: Abortable) => data, options?: Pick<ReadableOperatorOptions, "signal" | "concurrency">): Promise<undefined | T>
Parâmetros
- fn
-
(data: any, options?: Abortable) => data
uma função para chamar cada pedaço do fluxo. Assíncrono ou não.
- options
-
Pick<ReadableOperatorOptions, "signal" | "concurrency">
Devoluções
Promise<undefined | T>
uma promessa avaliada para o primeiro bloco para o qual fn avaliou com um valor truthy, ou undefined se não foi encontrado nenhum elemento.
flatMap((data: any, options?: Abortable) => any, Pick<ReadableOperatorOptions, "signal" | "concurrency">)
Este método devolve um novo fluxo aplicando o callback dado a cada bloco do fluxo e depois achatando o resultado.
É possível devolver um fluxo ou outro iterável iterável ou assíncrono a partir do fn e os fluxos resultantes serão fundidos (achatados) no fluxo devolvido.
function flatMap(fn: (data: any, options?: Abortable) => any, options?: Pick<ReadableOperatorOptions, "signal" | "concurrency">): Readable
Parâmetros
- fn
-
(data: any, options?: Abortable) => any
uma função para mapear cada bloco do fluxo. Pode ser assíncrono. Pode ser um fluxo de água ou gerador.
- options
-
Pick<ReadableOperatorOptions, "signal" | "concurrency">
Devoluções
um fluxo mapeado planamente com a função fn.
forEach((data: any, options?: Abortable) => void | Promise<void>, Pick<ReadableOperatorOptions, "signal" | "concurrency">)
Este método permite iterar um fluxo. Para cada bloco no fluxo, a função fn será chamada.
Se a função fn devolver uma promessa – essa promessa será awaited.
Este método é diferente dos for await...of loops porque pode, opcionalmente, processar chunks em simultâneo.
Além disso, uma forEach iteração só pode ser interrompida passando uma signal opção e abortando o AbortController relacionado, enquanto for await...of pode ser interrompida com break ou return.
Em qualquer dos casos, o riacho será destruído.
Este método difere de ouvir o 'data' evento, pois utiliza o readable evento na maquinaria subjacente e pode limitar o número de chamadas fn simultâneas.
function forEach(fn: (data: any, options?: Abortable) => void | Promise<void>, options?: Pick<ReadableOperatorOptions, "signal" | "concurrency">): Promise<void>
Parâmetros
- fn
-
(data: any, options?: Abortable) => void | Promise<void>
uma função para chamar cada pedaço do fluxo. Assíncrono ou não.
- options
-
Pick<ReadableOperatorOptions, "signal" | "concurrency">
Devoluções
Promise<void>
uma promessa para quando a transmissão terminar.
from(Iterable<any> | AsyncIterable<any>, ReadableOptions<Readable>)
Um método utilitário para criar Fluxos Legíveis a partir de iteradores.
static function from(iterable: Iterable<any> | AsyncIterable<any>, options?: ReadableOptions<Readable>): Readable
Parâmetros
- iterable
-
Iterable<any> | AsyncIterable<any>
Objeto a implementar o Symbol.asyncIterator protocolo iterável Symbol.iterator . Emite um evento de 'erro' se for transmitido um valor nulo.
- options
-
ReadableOptions<Readable>
Opções fornecidas a new stream.Readable([options]). Por defeito, Readable.from() definirá options.objectMode para true, a menos que isto seja explicitamente excluído definindo options.objectMode para false.
Devoluções
fromWeb(ReadableStream<any>, Pick<ReadableOptions<Readable>, "encoding" | "highWaterMark" | "objectMode" | "signal">)
Um método utilitário para criar um Readable a partir de uma web ReadableStream.
static function fromWeb(readableStream: ReadableStream<any>, options?: Pick<ReadableOptions<Readable>, "encoding" | "highWaterMark" | "objectMode" | "signal">): Readable
Parâmetros
- readableStream
-
ReadableStream<any>
- options
-
Pick<ReadableOptions<Readable>, "encoding" | "highWaterMark" | "objectMode" | "signal">
Devoluções
isDisturbed(ReadableStream<any> | ReadableStream)
Devolve se a transmissão foi lida ou cancelada.
static function isDisturbed(stream: ReadableStream<any> | ReadableStream): boolean
Parâmetros
- stream
-
ReadableStream<any> | ReadableStream
Devoluções
boolean
isPaused()
O readable.isPaused() método devolve o estado operacional atual do Readable.
Isto é usado principalmente pelo mecanismo que sustenta o readable.pipe() método.
Na maioria dos casos típicos, não haverá razão para usar este método diretamente.
const readable = new stream.Readable();
readable.isPaused(); // === false
readable.pause();
readable.isPaused(); // === true
readable.resume();
readable.isPaused(); // === false
function isPaused(): boolean
Devoluções
boolean
iterator(ReadableIteratorOptions)
O iterador criado por este método dá aos utilizadores a opção de cancelar a destruição do fluxo se o for await...of ciclo for encerrado por return, break, ou throw, ou se o iterador destruir o fluxo caso este emitisse um erro durante a iteração.
function iterator(options?: ReadableIteratorOptions): AsyncIterator<any, undefined, any>
Parâmetros
- options
-
ReadableIteratorOptions
Devoluções
AsyncIterator<any, undefined, any>
listenerCount(string | symbol, (args: any[]) => void)
function listenerCount(eventName: string | symbol, listener?: (args: any[]) => void): number
Parâmetros
- eventName
-
string | symbol
- listener
-
(args: any[]) => void
Devoluções
number
listenerCount<E>(E, (args: ReadableEventMap[E]) => void)
function listenerCount<E>(eventName: E, listener?: (args: ReadableEventMap[E]) => void): number
Parâmetros
- eventName
-
E
- listener
-
(args: ReadableEventMap[E]) => void
Devoluções
number
listeners(string | symbol)
function listeners(eventName: string | symbol): (args: any[]) => void[]
Parâmetros
- eventName
-
string | symbol
Devoluções
(args: any[]) => void[]
listeners<E>(E)
function listeners<E>(eventName: E): (args: ReadableEventMap[E]) => void[]
Parâmetros
- eventName
-
E
Devoluções
(args: ReadableEventMap[E]) => void[]
map((data: any, options?: Abortable) => any, ReadableOperatorOptions)
Este método permite mapear sobre o riacho. A função fn será chamada para cada bloco do fluxo.
Se a função fn devolver uma promessa - essa promessa será awaited antes de ser passada para o fluxo de resultados.
function map(fn: (data: any, options?: Abortable) => any, options?: ReadableOperatorOptions): Readable
Parâmetros
- fn
-
(data: any, options?: Abortable) => any
uma função para mapear cada bloco do fluxo. Assíncrono ou não.
- options
-
ReadableOperatorOptions
Devoluções
um fluxo mapeado com a função fn.
off(string | symbol, (args: any[]) => void)
function off(eventName: string | symbol, listener: (args: any[]) => void): Readable
Parâmetros
- eventName
-
string | symbol
- listener
-
(args: any[]) => void
Devoluções
off<E>(E, (args: ReadableEventMap[E]) => void)
function off<E>(eventName: E, listener: (args: ReadableEventMap[E]) => void): Readable
Parâmetros
- eventName
-
E
- listener
-
(args: ReadableEventMap[E]) => void
Devoluções
on(string | symbol, (args: any[]) => void)
function on(eventName: string | symbol, listener: (args: any[]) => void): Readable
Parâmetros
- eventName
-
string | symbol
- listener
-
(args: any[]) => void
Devoluções
on<E>(E, (args: ReadableEventMap[E]) => void)
function on<E>(eventName: E, listener: (args: ReadableEventMap[E]) => void): Readable
Parâmetros
- eventName
-
E
- listener
-
(args: ReadableEventMap[E]) => void
Devoluções
once(string | symbol, (args: any[]) => void)
function once(eventName: string | symbol, listener: (args: any[]) => void): Readable
Parâmetros
- eventName
-
string | symbol
- listener
-
(args: any[]) => void
Devoluções
once<E>(E, (args: ReadableEventMap[E]) => void)
function once<E>(eventName: E, listener: (args: ReadableEventMap[E]) => void): Readable
Parâmetros
- eventName
-
E
- listener
-
(args: ReadableEventMap[E]) => void
Devoluções
pause()
O readable.pause() método fará com que um fluxo em modo de fluxo pare de emitir 'data' eventos, saindo do modo de fluxo. Quaisquer dados que fiquem disponíveis permanecerão no buffer interno.
const readable = getReadableStreamSomehow();
readable.on('data', (chunk) => {
console.log(`Received ${chunk.length} bytes of data.`);
readable.pause();
console.log('There will be no additional data for 1 second.');
setTimeout(() => {
console.log('Now data will start flowing again.');
readable.resume();
}, 1000);
});
O readable.pause() método não tem efeito se houver um 'readable' ouvinte de eventos.
function pause(): Readable
Devoluções
prependListener(string | symbol, (args: any[]) => void)
function prependListener(eventName: string | symbol, listener: (args: any[]) => void): Readable
Parâmetros
- eventName
-
string | symbol
- listener
-
(args: any[]) => void
Devoluções
prependListener<E>(E, (args: ReadableEventMap[E]) => void)
function prependListener<E>(eventName: E, listener: (args: ReadableEventMap[E]) => void): Readable
Parâmetros
- eventName
-
E
- listener
-
(args: ReadableEventMap[E]) => void
Devoluções
prependOnceListener(string | symbol, (args: any[]) => void)
function prependOnceListener(eventName: string | symbol, listener: (args: any[]) => void): Readable
Parâmetros
- eventName
-
string | symbol
- listener
-
(args: any[]) => void
Devoluções
prependOnceListener<E>(E, (args: ReadableEventMap[E]) => void)
function prependOnceListener<E>(eventName: E, listener: (args: ReadableEventMap[E]) => void): Readable
Parâmetros
- eventName
-
E
- listener
-
(args: ReadableEventMap[E]) => void
Devoluções
push(any, BufferEncoding)
function push(chunk: any, encoding?: BufferEncoding): boolean
Parâmetros
- chunk
-
any
- encoding
-
BufferEncoding
Devoluções
boolean
rawListeners(string | symbol)
function rawListeners(eventName: string | symbol): (args: any[]) => void[]
Parâmetros
- eventName
-
string | symbol
Devoluções
(args: any[]) => void[]
rawListeners<E>(E)
function rawListeners<E>(eventName: E): (args: ReadableEventMap[E]) => void[]
Parâmetros
- eventName
-
E
Devoluções
(args: ReadableEventMap[E]) => void[]
read(number)
O readable.read() método lê dados do buffer interno e devolve-os. Se não houver dados disponíveis para leitura, null é devolvido. Por defeito, os dados são devolvidos como objeto Buffer , a menos que uma codificação tenha sido especificada usando o readable.setEncoding() método ou que o fluxo esteja a operar em modo objeto.
O argumento opcional size especifica um número específico de bytes a ler. Se size os bytes não estiverem disponíveis para leitura, null serão devolvidos a menos que o fluxo tenha terminado, caso em que todos os dados restantes no buffer interno serão devolvidos.
Se o size argumento não for especificado, todos os dados contidos no buffer interno serão devolvidos.
O size argumento deve ser menor ou igual a 1 GiB.
O readable.read() método deve ser chamado apenas em Readable fluxos que operam em modo pausado. No modo de fluxo, readable.read() é chamado automaticamente até que o buffer interno esteja totalmente drenado.
const readable = getReadableStreamSomehow();
// 'readable' may be triggered multiple times as data is buffered in
readable.on('readable', () => {
let chunk;
console.log('Stream is readable (new data received in buffer)');
// Use a loop to make sure we read all currently available data
while (null !== (chunk = readable.read())) {
console.log(`Read ${chunk.length} bytes of data...`);
}
});
// 'end' will be triggered once when there is no more data available
readable.on('end', () => {
console.log('Reached end of stream.');
});
Cada chamada para readable.read() devolve um bloco de dados, ou null. Os chunks não são concatenados. É necessário um while ciclo para consumir todos os dados atualmente no buffer. Ao ler, um ficheiro .read() grande pode devolver null, tendo consumido todo o conteúdo armazenado até agora, mas ainda há mais dados por vir, ainda não armazenados. Neste caso, um novo 'readable' evento será emitido quando houver mais dados no buffer. Finalmente, o 'end' evento será emitido quando não houver mais dados disponíveis.
Portanto, para ler todo o conteúdo de um ficheiro a partir de um readable, é necessário recolher blocos de múltiplos 'readable' eventos:
const chunks = [];
readable.on('readable', () => {
let chunk;
while (null !== (chunk = readable.read())) {
chunks.push(chunk);
}
});
readable.on('end', () => {
const content = chunks.join('');
});
Um Readable fluxo em modo objeto devolverá sempre um único item de uma chamada para readable.read(size), independentemente do valor do size argumento.
Se o readable.read() método devolver um bloco de dados, também será emitido um 'data' evento.
A chamada de leitura após o 'end' evento ter sido emitido retornará null. Não será apresentado nenhum erro de execução.
function read(size?: number): any
Parâmetros
- size
-
number
Argumento opcional para especificar quantos dados ler.
Devoluções
any
reduce<T>((previous: any, data: any, options?: Abortable) => T)
Este método chama fn em cada bloco do fluxo por ordem, passando-lhe o resultado do cálculo no elemento anterior. Devolve uma promessa do valor final da redução.
Se não for fornecido valor inicial , o primeiro bloco do fluxo é usado como valor inicial.
Se o fluxo estiver vazio, a promessa é rejeitada com a TypeErrorERR_INVALID_ARGS propriedade de código.
A função redutora itera o fluxo elemento a elemento, o que significa que não existe parâmetro de concorrência nem paralelismo. Para realizar uma redução simultaneamente, pode extrair a função assíncrona do readable.map método.
function reduce<T>(fn: (previous: any, data: any, options?: Abortable) => T): Promise<T>
Parâmetros
- fn
-
(previous: any, data: any, options?: Abortable) => T
uma função redutora para chamar todos os blocos do fluxo. Assíncrono ou não.
Devoluções
Promise<T>
uma promessa do valor final da redução.
reduce<T>((previous: T, data: any, options?: Abortable) => T, T, Abortable)
function reduce<T>(fn: (previous: T, data: any, options?: Abortable) => T, initial: T, options?: Abortable): Promise<T>
Parâmetros
- fn
-
(previous: T, data: any, options?: Abortable) => T
- initial
-
T
- options
-
Abortable
Devoluções
Promise<T>
removeAllListeners(string | symbol)
function removeAllListeners(eventName?: string | symbol): Readable
Parâmetros
- eventName
-
string | symbol
Devoluções
removeAllListeners<E>(E)
removeListener(string | symbol, (args: any[]) => void)
function removeListener(eventName: string | symbol, listener: (args: any[]) => void): Readable
Parâmetros
- eventName
-
string | symbol
- listener
-
(args: any[]) => void
Devoluções
removeListener<E>(E, (args: ReadableEventMap[E]) => void)
function removeListener<E>(eventName: E, listener: (args: ReadableEventMap[E]) => void): Readable
Parâmetros
- eventName
-
E
- listener
-
(args: ReadableEventMap[E]) => void
Devoluções
resume()
O readable.resume() método faz com que um fluxo explicitamente Readable pausado retome a 'data' emissão de eventos, mudando o fluxo para modo de fluxo.
O readable.resume() método pode ser usado para consumir totalmente os dados de um fluxo sem realmente processar nenhum desses dados:
getReadableStreamSomehow()
.resume()
.on('end', () => {
console.log('Reached the end, but did not read anything.');
});
O readable.resume() método não tem efeito se houver um 'readable' ouvinte de eventos.
function resume(): Readable
Devoluções
setEncoding(BufferEncoding)
O readable.setEncoding() método define a codificação de caracteres para os dados lidos do Readable fluxo.
Por defeito, não é atribuída codificação e os dados do fluxo serão devolvidos como Buffer objetos. Definir uma codificação faz com que os dados do fluxo sejam devolvidos como cadeias da codificação especificada em vez de como Buffer objetos. Por exemplo, ao chamar readable.setEncoding('utf8') , os dados de saída são interpretados como dados UTF-8 e passados como strings. A chamada readable.setEncoding('hex') fará com que os dados sejam codificados em formato de string hexadecimal.
O Readable fluxo lida corretamente com caracteres multibyte entregues através do fluxo que, de outra forma, seriam decodificados incorretamente se simplesmente puxados do fluxo como Buffer objetos.
const readable = getReadableStreamSomehow();
readable.setEncoding('utf8');
readable.on('data', (chunk) => {
assert.equal(typeof chunk, 'string');
console.log('Got %d characters of string data:', chunk.length);
});
function setEncoding(encoding: BufferEncoding): Readable
Parâmetros
- encoding
-
BufferEncoding
A codificação a usar.
Devoluções
some((data: any, options?: Abortable) => boolean | Promise<boolean>, Pick<ReadableOperatorOptions, "signal" | "concurrency">)
Este método é semelhante a Array.prototype.some e chama fn em cada bloco do fluxo até que o valor de retorno aguardado seja true (ou qualquer valor truthy). Uma vez que uma chamada fn num valor de retorno de chunk awaited é verdadeira, o fluxo é destruído e a promessa é cumprida com true.
Se nenhum dos fn calls nos chunks devolver um valor truthy, a promessa é cumprida com false.
function some(fn: (data: any, options?: Abortable) => boolean | Promise<boolean>, options?: Pick<ReadableOperatorOptions, "signal" | "concurrency">): Promise<boolean>
Parâmetros
- fn
-
(data: any, options?: Abortable) => boolean | Promise<boolean>
uma função para chamar cada pedaço do fluxo. Assíncrono ou não.
- options
-
Pick<ReadableOperatorOptions, "signal" | "concurrency">
Devoluções
Promise<boolean>
Uma promessa que avalia se trueo FN devolveu um valor truthy para pelo menos um dos chunks.
take(number, Abortable)
Este método devolve um novo fluxo com os primeiros blocos limite .
function take(limit: number, options?: Abortable): Readable
Parâmetros
- limit
-
number
O número de blocos a retirar do legível.
- options
-
Abortable
Devoluções
um stream com blocos de limite ocupados.
toArray(Abortable)
Este método permite obter facilmente o conteúdo de um fluxo.
Como este método lê todo o fluxo na memória, anula os benefícios dos fluxos. Destina-se à interoperabilidade e conveniência, não a principal forma de consumir streams.
function toArray(options?: Abortable): Promise<any[]>
Parâmetros
- options
-
Abortable
Devoluções
Promise<any[]>
uma promessa contendo um array com o conteúdo do fluxo.
toWeb(ReadableStream, ReadableToWebOptions)
Um método utilitário para criar uma teia ReadableStream a partir de um Readable.
static function toWeb(streamReadable: ReadableStream, options?: ReadableToWebOptions): ReadableStream<any>
Parâmetros
- streamReadable
-
ReadableStream
- options
-
ReadableToWebOptions
Devoluções
ReadableStream<any>
unpipe(WritableStream)
O readable.unpipe() método destaca um Writable jato previamente ligado usando o método do tubo .
Se o destination não for especificado, então todos os tubos são destacados.
Se o destination for especificado, mas não estiver configurado nenhum tubo para isso, então o método não faz nada.
import fs from 'node:fs';
const readable = getReadableStreamSomehow();
const writable = fs.createWriteStream('file.txt');
// All the data from readable goes into 'file.txt',
// but only for the first second.
readable.pipe(writable);
setTimeout(() => {
console.log('Stop writing to file.txt.');
readable.unpipe(writable);
console.log('Manually close the file stream.');
writable.end();
}, 1000);
function unpipe(destination?: WritableStream): Readable
Parâmetros
- destination
-
WritableStream
Fluxo específico opcional para despipear
Devoluções
unshift(any, BufferEncoding)
Passar chunk como null sinaliza o fim do fluxo (EOF) e comporta-se da mesma forma que readable.push(null), após o que não podem ser escritos mais dados. O sinal EOF é colocado no final do buffer e quaisquer dados armazenados em buffer continuam a ser eliminados.
O readable.unshift() método empurra um pedaço de dados de volta para o buffer interno. Isto é útil em certas situações em que um fluxo está a ser consumido por código que precisa de "desconsumir" uma certa quantidade de dados que otimisticamente retirou da fonte, para que os dados possam ser transmitidos a outra parte.
O stream.unshift(chunk) método não pode ser chamado depois de o 'end' evento ter sido emitido, caso contrário será lançado um erro em tempo de execução.
Os programadores que usam stream.unshift() frequentemente devem considerar mudar para o uso de um Transform stream em vez disso. Consulte a API for stream implementers secção para mais informações.
// Pull off a header delimited by \n\n.
// Use unshift() if we get too much.
// Call the callback with (error, header, stream).
import { StringDecoder } from 'node:string_decoder';
function parseHeader(stream, callback) {
stream.on('error', callback);
stream.on('readable', onReadable);
const decoder = new StringDecoder('utf8');
let header = '';
function onReadable() {
let chunk;
while (null !== (chunk = stream.read())) {
const str = decoder.write(chunk);
if (str.includes('\n\n')) {
// Found the header boundary.
const split = str.split(/\n\n/);
header += split.shift();
const remaining = split.join('\n\n');
const buf = Buffer.from(remaining, 'utf8');
stream.removeListener('error', callback);
// Remove the 'readable' listener before unshifting.
stream.removeListener('readable', onReadable);
if (buf.length)
stream.unshift(buf);
// Now the body of the message can be read from the stream.
callback(null, header, stream);
return;
}
// Still reading the header.
header += str;
}
}
}
Ao contrário do push, stream.unshift(chunk) não termina o processo de leitura ao reiniciar o estado interno de leitura do fluxo.
Isto pode causar resultados inesperados se readable.unshift() for chamado durante uma leitura (ou seja, a partir de uma implementação _read num fluxo personalizado). Seguir a chamada readable.unshift() com um push imediato irá reiniciar o estado de leitura corretamente, no entanto, é melhor simplesmente evitar ligar readable.unshift() durante o processo de leitura.
function unshift(chunk: any, encoding?: BufferEncoding)
Parâmetros
- chunk
-
any
Pedaço de dados para deslocar para a fila de leitura. Para fluxos que não operam em modo objeto, chunk deve ser uma {string}, {Buffer}, {TypedArray}, {DataView} ou null. Para fluxos em modo objeto, chunk pode ser qualquer valor JavaScript.
- encoding
-
BufferEncoding
Codificação de blocos de cadeia. Deve ser uma codificação válida Buffer , como 'utf8' ou 'ascii'.
wrap(ReadableStream)
Antes do Node.js 0.10, os fluxos não implementavam toda node:stream a API do módulo tal como está atualmente definida. (Ver Compatibility para mais informações.)
Ao usar uma biblioteca Node.js antiga que emite 'data' eventos e tem um método de pausa apenas consultivo, o readable.wrap() método pode ser usado para criar um Readable fluxo que utiliza o fluxo antigo como fonte de dados.
Raramente será necessário utilizá-lo readable.wrap() , mas o método foi disponibilizado como uma conveniência para interagir com aplicações e bibliotecas Node.js mais antigas.
import { OldReader } from './old-api-module.js';
import { Readable } from 'node:stream';
const oreader = new OldReader();
const myReader = new Readable().wrap(oreader);
myReader.on('readable', () => {
myReader.read(); // etc.
});
function wrap(stream: ReadableStream): Readable
Parâmetros
- stream
-
ReadableStream
Um fluxo legível de "estilo antigo"
Devoluções
[asyncIterator]()
function [asyncIterator](): AsyncIterator<any, undefined, any>
Devoluções
AsyncIterator<any, undefined, any>
AsyncIterator para consumir totalmente o fluxo.
Detalhes do Método Herdado
eventNames()
Retorna uma matriz listando os eventos para os quais o emissor registrou ouvintes.
import { EventEmitter } from 'node:events';
const myEE = new EventEmitter();
myEE.on('foo', () => {});
myEE.on('bar', () => {});
const sym = Symbol('symbol');
myEE.on(sym, () => {});
console.log(myEE.eventNames());
// Prints: [ 'foo', 'bar', Symbol(symbol) ]
function eventNames(): (string | symbol)[]
Devoluções
(string | symbol)[]
Herdado de Stream.eventNames
getMaxListeners()
Retorna o valor máximo de ouvinte atual para o EventEmitter que é definido por emitter.setMaxListeners(n) ou padrão como events.defaultMaxListeners.
function getMaxListeners(): number
Devoluções
number
Herdado de Stream.getMaxListeners
pipe<T>(T, PipeOptions)
function pipe<T>(destination: T, options?: PipeOptions): T
Parâmetros
- destination
-
T
- options
-
PipeOptions
Devoluções
T
Herdado de Stream.pipe
setMaxListeners(number)
Por padrãoEventEmitters imprimirá um aviso se mais de 10 ouvintes forem adicionados para um evento específico. Este é um padrão útil que ajuda a encontrar vazamentos de memória. O método emitter.setMaxListeners() permite que o limite seja modificado para esta instância EventEmitter específica. O valor pode ser definido como Infinity (ou 0) para indicar um número ilimitado de ouvintes.
Retorna uma referência ao EventEmitter, para que as chamadas possam ser encadeadas.
function setMaxListeners(n: number): Readable
Parâmetros
- n
-
number
Devoluções
Herdado de Stream.setMaxOuvintes
[captureRejectionSymbol](Error, string | symbol, any[])
O Symbol.for('nodejs.rejection') método é chamado caso ocorra uma rejeição de promessa ao emitir um evento e captureRejections está ativado no emissor.
É possível usar events.captureRejectionSymbol em vez de Symbol.for('nodejs.rejection').
import { EventEmitter, captureRejectionSymbol } from 'node:events';
class MyClass extends EventEmitter {
constructor() {
super({ captureRejections: true });
}
[captureRejectionSymbol](err, event, ...args) {
console.log('rejection happened for', event, 'with', err, ...args);
this.destroy(err);
}
destroy(err) {
// Tear the resource down here.
}
}
function [captureRejectionSymbol](error: Error, event: string | symbol, args: any[])
Parâmetros
- error
-
Error
- event
-
string | symbol
- args
-
any[]
Herdado de Stream.__@captureRejectionSymbol@175