WebTransport: Methode createUnidirectionalStream()

Limited availability

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

Sicherer Kontext: Diese Funktion ist nur in sicheren Kontexten (HTTPS) in einigen oder allen unterstützenden Browsern verfügbar.

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

Die createUnidirectionalStream()-Methode des WebTransport-Interfaces öffnet asynchron einen unidirektionalen Stream.

Die Methode gibt ein Promise zurück, das zu einem WritableStream-Objekt auflöst, welches verwendet werden kann, um zuverlässig Daten an den Server zu schreiben.

"Zuverlässig" bedeutet, dass die Übertragung und Reihenfolge der Daten garantiert werden. Dies führt zu einer langsameren Zustellung (obwohl schneller als mit WebSockets) als bei datagrams, ist jedoch in Situationen erforderlich, in denen Zuverlässigkeit und Ordnung wichtig sind, wie z.B. bei Chat-Anwendungen.

Die relative Reihenfolge, in der die angestellten Bytes aus erstellten Streams geleert werden, kann mit der sendOrder-Option spezifiziert werden. Wenn gesetzt, werden angestellte Bytes in Streams mit einer höheren Sendepriorität garantiert vor den angestellten Bytes für Streams mit einer niedrigeren Sendepriorität gesendet. Wenn die Ordnungsnummer nicht gesetzt ist, dann hängt die Reihenfolge, in der Bytes gesendet werden, von der Implementierung ab. Beachten Sie jedoch, dass selbst wenn Bytes aus Streams mit höherer Sendepriorität zuerst gesendet werden, sie möglicherweise nicht als erstes ankommen.

Syntax

js
createUnidirectionalStream()
createUnidirectionalStream(options)

Parameter

options Optional

Ein Objekt, das die folgenden Eigenschaften haben kann:

sendOrder Optional

Ein ganzzahliger Wert, der die Sendepriorität dieses Streams relativ zu anderen Streams, für die der Wert gesetzt wurde, angibt. Angestellte Bytes werden zuerst für Streams gesendet, die einen höheren Wert haben. Wenn nicht gesetzt, hängt die Sendepriorität von der Implementierung ab.

Rückgabewert

Ein Promise, das zu einem WebTransportSendStream-Objekt auflöst (dies ist ein WritableStream).

Ausnahmen

InvalidStateError DOMException

Wird ausgelöst, wenn createUnidirectionalStream() aufgerufen wird, während die WebTransport-Verbindung geschlossen oder fehlgeschlagen ist.

Beispiele

Verwenden Sie die createUnidirectionalStream()-Methode, um eine Referenz zu einem WritableStream zu erhalten. Daraus können Sie einen Schreiber erhalten, um Daten in den Stream zu schreiben und an den Server zu senden.

Verwenden Sie die close()-Methode des resultierenden WritableStreamDefaultWriter, um die zugehörige HTTP/3-Verbindung zu schließen. Der Browser versucht, alle anstehenden Daten zu senden, bevor die zugehörige Verbindung tatsächlich geschlossen wird.

js
async function writeData() {
  const stream = await transport.createUnidirectionalStream({
    sendOrder: "596996858",
  });
  const writer = stream.getWriter();
  const data1 = new Uint8Array([65, 66, 67]);
  const data2 = new Uint8Array([68, 69, 70]);
  writer.write(data1);
  writer.write(data2);

  try {
    await writer.close();
    console.log("All data has been sent.");
  } catch (error) {
    console.error(`An error occurred: ${error}`);
  }
}

Sie können auch WritableStreamDefaultWriter.abort() verwenden, um den Stream abrupt zu beenden. Beim Verwenden von abort() kann der Browser alle anstehenden Daten verwerfen, die noch nicht gesendet wurden.

js
// …

const stream = await transport.createUnidirectionalStream();
const writer = stream.getWriter();

// …

writer.write(data1);
writer.write(data2);
await writer.abort();
// Not all the data may have been written.

Spezifikationen

Specification
WebTransport
# dom-webtransport-createunidirectionalstream

Browser-Kompatibilität

Siehe auch