Dieser Inhalt wurde automatisch aus dem Englischen übersetzt, und kann Fehler enthalten. Erfahre mehr über dieses Experiment.

View in English Always switch to English

ReadableByteStreamController

Limited availability

This feature is not Baseline because it does not work in some of the most widely-used browsers.

Hinweis: Diese Funktion ist in Web Workers verfügbar.

Das ReadableByteStreamController-Interface der Streams API repräsentiert einen Controller für einen lesbaren Byte-Strom. Es ermöglicht die Steuerung des Zustands und der internen Warteschlange eines ReadableStream mit einer zugrundeliegenden Byte-Quelle und erlaubt eine effiziente Zero-Copy-Übertragung von Daten von der zugrundeliegenden Quelle zu einem Verbraucher, wenn die interne Warteschlange des Streams leer ist.

Eine Instanz dieses Controllertyps wird erstellt, wenn ein underlyingSource-Objekt mit der Eigenschaft type="bytes" als Argument an den ReadableStream()-Konstruktor übergeben wird. Das underlyingSource-Objekt kann auch die Callback-Funktionen start() und pull() definieren. Diese werden mit dem Controller als Parameter aufgerufen, um die zugrundeliegende Quelle einzurichten und Daten anzufordern, wenn sie benötigt werden.

Die zugrundeliegende Quelle verwendet den Controller, um Daten dem Stream über seine Eigenschaft byobRequest oder die Methode enqueue() bereitzustellen. byobRequest ist ein ReadableStreamBYOBRequest-Objekt, das eine ausstehende Anforderung von einem Verbraucher darstellt, um eine Zero-Copy-Übertragung von Daten direkt zu einem Verbraucher durchzuführen. byobRequest muss verwendet werden, um Daten zu kopieren, wenn es existiert (verwenden Sie in diesem Fall nicht enqueue())! Wenn die zugrundeliegende Quelle Daten an den Stream übergeben muss und byobRequest null ist, kann die Quelle enqueue() aufrufen, um die Daten zu den internen Warteschlangen des Streams hinzuzufügen.

Beachten Sie, dass der byobRequest nur im "BYOB-Modus" erstellt wird, wenn eine Anforderung von einem Leser vorliegt und die interne Warteschlange des Streams leer ist. Der "BYOB-Modus" wird aktiviert, wenn ein ReadableStreamBYOBReader verwendet wird (typischerweise erstellt durch Aufrufen von ReadableStream.getReader() mit dem Argument { mode: 'byob' }). Er wird auch aktiviert, wenn ein Standardleser verwendet wird und autoAllocateChunkSize im ReadableStream()-Konstruktor angegeben ist.

Eine zugrundeliegende Byte-Quelle kann den Controller auch verwenden, um den Stream zu close(), wenn alle Daten gesendet wurden, und Fehler von der zugrundeliegenden Quelle mit error() zu melden. Die Eigenschaft desiredSize des Controllers wird verwendet, um "Gegendruck" zu erzeugen, indem der zugrundeliegenden Quelle die Größe der internen Warteschlange mitgeteilt wird (kleine Werte zeigen an, dass die Warteschlange sich füllt, was der zugrundeliegenden Quelle signalisiert, dass es wünschenswert wäre, den Zufluss zu pausieren oder zu drosseln).

Beachten Sie, dass auch wenn der Controller primär von der zugrundeliegenden Byte-Quelle verwendet wird, es keinen Grund gibt, warum er nicht von anderen Teilen des Systems gespeichert und genutzt werden kann, um das Signal an den Stream zu senden.

Konstruktor

Keiner. ReadableByteStreamController-Instanzen werden automatisch erstellt, wenn ein underlyingSource mit der Eigenschaft type="bytes" an den ReadableStream()-Konstruktor übergeben wird.

Instanzeigenschaften

ReadableByteStreamController.byobRequest Schreibgeschützt

Gibt die aktuelle BYOB-Anforderung zurück oder null, wenn keine ausstehende Anforderung vorliegt.

ReadableByteStreamController.desiredSize Schreibgeschützt

Gibt die gewünschte Größe zurück, die erforderlich ist, um die interne Warteschlange des Streams zu füllen.

Instanzmethoden

ReadableByteStreamController.close()

Schließt den zugeordneten Stream.

ReadableByteStreamController.enqueue()

Fügt einen gegebenen Datenblock in den zugeordneten Stream ein.

ReadableByteStreamController.error()

Führt dazu, dass alle zukünftigen Interaktionen mit dem zugeordneten Stream fehlschlagen.

Beispiele

Der Controller wird von einer zugrundeliegenden Quelle verwendet, um Daten zu übertragen oder einzureihen, um zu signalisieren, dass der Stream keine Daten mehr hat (geschlossen wurde) oder einen Fehler aufgetreten ist. Er wird auch verwendet, um der zugrundeliegenden Quelle von "oberhalb im Stream" die gewünschte Datenrate mit desiredSize zu signalisieren.

Das Beispiel in Verwendung von lesbaren Byte-Streams, insbesondere Erstellen eines lesbaren Socket-Push-Byte-Streams, zeigt die meisten dieser Fälle.

Spezifikationen

Specification
Streams
# rbs-controller-class

Browser-Kompatibilität

Siehe auch