1. 開発者向けのウェブ技術
  2. Web API
  3. TransformStream

このページはコミュニティーの尽力で英語から翻訳されました。MDN Web Docs コミュニティーについてもっと知り、仲間になるにはこちらから。

View in English Always switch to English

TransformStream

Baseline 広く利用可能 *

この機能は広く実装されており、多くのバージョンの端末やブラウザーで動作します。2022年6月以降、すべてのブラウザーで利用可能です。

* この機能の一部は、対応レベルが異なる場合があります。

TransformStreamストリーム API のインターフェイスで、変換ストリームの概念であるパイプチェーンの具体的な実装を表します。

これは、データのストリームをある形式から別の形式に変換するために ReadableStream.pipeThrough() メソッドに渡すことができます。 例えば、動画フレームをデコード(またはエンコード)したり、データを解凍したり、ストリームを XML から JSON に変換したりするために使用します。

変換アルゴリズムは、オブジェクトのコンストラクターのオプション引数として指定されます。 提供されない場合、ストリームを通してパイプ処理されたデータは変更されません。

TransformStream移譲可能オブジェクトです。

コンストラクター

TransformStream()

指定されたハンドラーから変換ストリームを作成して返却します。オプションで、変換オブジェクトとストリームのキューイング戦略を指定します。

インスタンスプロパティ

TransformStream.readable 読取専用

TransformStreamreadable 側の端点です。

TransformStream.writable 読取専用

TransformStreamwritable 側の端点です。

インスタンスメソッド

なし

何かを uint8array に変換するストリーム

以下の例では、変換ストリームは受信したすべてのチャンクを Uint8Array の値に渡します。

js
const transformContent = {
 start() {}, // required.
 async transform(chunk, controller) {
 chunk = await chunk;
 switch (typeof chunk) {
 case "object":
 // just say the stream is done I guess
 if (chunk === null) {
 controller.terminate();
 } else if (ArrayBuffer.isView(chunk)) {
 controller.enqueue(
 new Uint8Array(chunk.buffer, chunk.byteOffset, chunk.byteLength),
 );
 } else if (
 Array.isArray(chunk) &&
 chunk.every((value) => typeof value === "number")
 ) {
 controller.enqueue(new Uint8Array(chunk));
 } else if (
 typeof chunk.valueOf === "function" &&
 chunk.valueOf() !== chunk
 ) {
 this.transform(chunk.valueOf(), controller); // hack
 } else if ("toJSON" in chunk) {
 this.transform(JSON.stringify(chunk), controller);
 }
 break;
 case "symbol":
 controller.error("Cannot send a symbol as a chunk part");
 break;
 case "undefined":
 controller.error("Cannot send undefined as a chunk part");
 break;
 default:
 controller.enqueue(this.textencoder.encode(String(chunk)));
 break;
 }
 },
 flush() {
 /* do any destructor work here */
 },
};
class AnyToU8Stream extends TransformStream {
 constructor() {
 super({ ...transformContent, textencoder: new TextEncoder() });
 }
}

TextEncoderStream および TextDecoderStream の代替

なお、これはネイティブのコンストラクターを使っているため非推奨です。これは対応していないプラットフォームで代替とすることを意図しています。

js
const tes = {
 start() {
 this.encoder = new TextEncoder();
 },
 transform(chunk, controller) {
 controller.enqueue(this.encoder.encode(chunk));
 },
};
let _jstes_wm = new WeakMap(); /* info holder */
class JSTextEncoderStream extends TransformStream {
 constructor() {
 let t = { ...tes };
 super(t);
 _jstes_wm.set(this, t);
 }
 get encoding() {
 return _jstes_wm.get(this).encoder.encoding;
 }
}

同様に、 TextDecoderStream は次のように書くことができます。

js
const tds = {
 start() {
 this.decoder = new TextDecoder(this.encoding, this.options);
 },
 transform(chunk, controller) {
 controller.enqueue(this.decoder.decode(chunk, { stream: true }));
 },
};
let _jstds_wm = new WeakMap(); /* info holder */
class JSTextDecoderStream extends TransformStream {
 constructor(encoding = "utf-8", { ...options } = {}) {
 let t = { ...tds, encoding, options };
 super(t);
 _jstds_wm.set(this, t);
 }
 get encoding() {
 return _jstds_wm.get(this).decoder.encoding;
 }
 get fatal() {
 return _jstds_wm.get(this).decoder.fatal;
 }
 get ignoreBOM() {
 return _jstds_wm.get(this).decoder.ignoreBOM;
 }
}

複数の ReadableStreams を互いに結合

これは、複数のストリームを結合できる便利なものです。例ではプログレッシブ読み込みやプログレッシブストリーミングを持つ PWA の構築が含まれます。

js
let responses = [/* conjoined response tree */];
let { readable, writable } = new TransformStream();
responses.reduce(
 (a, res, i, arr) =>
 a.then(() => res.pipeTo(writable, { preventClose: i + 1 !== arr.length })),
 Promise.resolve(),
);

これは他への影響に対して耐性がないことに注意してください。

仕様書

仕様書
Streams
# ts-class

ブラウザーの互換性

関連情報

MDN の改良に協力

協力方法を知る

このページは MDN の貢献者によって に最終更新されました。

AltStyle によって変換されたページ (->オリジナル) /