RxJS-演算子

演算子はRxJSの重要な部分です。演算子は、オブザーバブルを入力として取り込む純粋関数であり、出力もオブザーバブルです。

オペレーターとの協力

演算子は、オブザーバブルを入力として取り込む純粋関数であり、出力もオブザーバブルです。

演算子を操作するには、pipe()メソッドが必要です。

pipe()の使用例

let obs = of(1,2,3); // an observable
obs.pipe(
   operator1(),
   operator2(),
   operator3(),
   operator3(),
)

上記の例では、を使用してオブザーバブルを作成しました of()値1、2、および3を受け取るメソッド。これで、このobservableで、上記のように、pipe()メソッドを使用して任意の数の演算子を使用してさまざまな操作を実行できます。演算子の実行は、指定されたオブザーバブルで順番に実行されます。

以下は実際の例です-

import { of } from 'rxjs';
import { map, reduce, filter } from 'rxjs/operators';

let test1 = of(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);
let case1 = test1.pipe(
   filter(x => x % 2 === 0),
   reduce((acc, one) => acc + one, 0)
)
case1.subscribe(x => console.log(x));

出力

30

上記の例では、偶数をフィルタリングするフィルター演算子を使用し、次に使用しました reduce() 偶数の値を追加し、サブスクライブ時に結果を提供する演算子。

これが、これから説明するObservableのリストです。

  • Creation
  • Mathematical
  • Join
  • Transformation
  • Filtering
  • Utility
  • Conditional
  • Multicasting
  • エラー処理

生成演算子

以下は、作成演算子カテゴリで説明する演算子です。

シニア番号 オペレーターと説明
1 ajax

このオペレーターは、指定されたURLに対してajaxリクエストを行います。

2 から

この演算子は、配列、配列のようなオブジェクト、promise、反復可能なオブジェクト、またはobservableのようなオブジェクトからobservableを作成します。

3 fromEvent

この演算子は、ボタンやクリックなどのイベントを発行する要素で使用されるオブザーバブルとして出力を提供します。

4 fromEventPattern

この演算子は、イベントハンドラーの登録に使用される入力関数からオブザーバブルを作成します。

5 間隔

この演算子は、指定された時間の間、毎回Observableを作成します。

6

この演算子は、渡された引数を受け取り、それらをobservableに変換します。

7 範囲

この演算子は、提供された範囲に基づいて一連の数値を提供するObservableを作成します。

8 throwError

この演算子は、エラーを通知するオブザーバブルを作成します。

9 タイマー

この演算子は、タイムアウト後に値を発行するオブザーバブルを作成し、呼び出しごとに値が増加し続けます。

10 iif

このオペレーターは、どのObservableをサブスクライブするかを決定します。

数学演算子

以下は、数学演算子のカテゴリで説明する演算子です。

シニア番号 オペレーターと説明
1 カウント

count()演算子は、値を持つObservableを受け取り、それを単一の値を与えるObservableに変換します

2 マックス

Maxメソッドは、すべての値でオブザーバブルを取り込み、最大値でオブザーバブルを返します

3 最小

Minメソッドは、すべての値でオブザーバブルを取り込み、最小値でオブザーバブルを返します。

4 減らす

reduce演算子では、入力オブザーバブルでアキュムレータ関数が使用され、アキュムレータ関数は、オプションのシード値がアキュムレータ関数に渡された状態で、累積値をオブザーバブルの形式で返します。

reduce()関数は、2つの引数、1つのアキュムレータ関数、2番目のシード値を取ります。

オペレーターに参加する

以下は、結合演算子カテゴリで説明する演算子です。

シニア番号 オペレーターと説明
1 concat

このオペレーターは、入力として指定されたObservableを順次発行し、次のObservableに進みます。

2 forkJoin

この演算子は、配列またはdictオブジェクトに入力として取り込まれ、オブザーバブルが完了するのを待って、指定されたオブザーバブルから発行された最後の値を返します。

3 マージ

この演算子は、入力オブザーバブルを取り込み、オブザーバブルからすべての値を出力し、単一の出力オブザーバブルを出力します。

4 人種

これは、最初のソースオブザーバブルのミラーコピーとなるオブザーバブルを返します。

変換演算子

以下は、変換演算子カテゴリで説明する演算子です。

シニア番号 オペレーターと説明
1 バッファ

バッファはオブザーバブルで動作し、引数をオブザーバブルとして受け取ります。配列内の元のオブザーバブルで発行された値のバッファリングを開始し、引数として取得されたオブザーバブルが発行するときに同じ値を発行します。引数として取得されたオブザーバブルが発行されると、バッファーがリセットされ、入力オブザーバブルが発行されて同じシナリオが繰り返されるまで、元のバッファーが再度開始されます。

2 bufferCount

buffercount()演算子の場合、呼び出されたオブザーバブルから値を収集し、buffercountに指定されたバッファーサイズが一致すると同じ値を出力します。

3 bufferTime

これはbufferCountに似ているため、ここでは、呼び出されたオブザーバブルから値を収集し、bufferTimeSpanを発行します。1つの引数、つまりbufferTimeSpanを取ります。

4 bufferToggle

bufferToggle()の場合、openingsとcloseingSelectorの2つの引数を取ります。開始引数はサブスクライブ可能であるか、バッファーを開始することを約束し、2番目の引数closeingSelectorは再びサブスクライブ可能であるか、バッファーを閉じて収集された値を発行するインジケーターを約束します。

5 bufferWhen

この演算子は、配列形式で値を指定します。これは、バッファーをいつ閉じ、発行し、リセットするかを決定する関数として1つの引数を取ります。

6 展開

展開演算子は、関数を引数として受け取ります。この関数は、ソースのオブザーバブルと出力のオブザーバブルに適用されます。最終的な値は観察可能です。

7 groupBy

groupBy演算子では、出力は特定の条件に基づいてグループ化され、これらのグループ項目はGroupedObservableとして出力されます。

8 地図

マップ演算子の場合、プロジェクト関数がソースObservableの各値に適用され、同じ出力がObservableとして出力されます。

9 mapTo

ソースObservableが値を発行するたびに、Observableとともに一定の値が出力として提供されます。

10 mergeMap

mergeMapオペレーターの場合、プロジェクト関数が各ソース値に適用され、その出力が出力Observableとマージされます。

11 switchMap

switchMap演算子の場合、プロジェクト関数が各ソース値に適用され、その出力が出力Observableとマージされ、指定された値が最新の予測されたObservableです。

12

これは、observableである引数windowboundariesを取り、指定されたwindowboundariesが発行するたびにネストされたobservableを返します。

フィルタリング演算子

以下は、フィルタリング演算子のカテゴリで説明する演算子です。

シニア番号 オペレーターと説明
1 デバウンス

しばらくしてソースObservableから放出された値であり、放出はObservableまたはpromiseとして指定された別の入力によって決定されます。

2 debounceTime

時間が完了した後にのみ、観測可能なソースから値を放出します。

3 明確な

この演算子は、前の値と比較したときに異なる、ソースオブザーバブルからのすべての値を提供します。

4 elementAt

この演算子は、指定されたインデックスに基づいて、監視可能なソースから単一の値を提供します。

5 フィルタ

この演算子は、指定された述語関数に基づいて、ソースObservableからの値をフィルタリングします。

6 最初

この演算子は、ソースObservableによって発行された最初の値を提供します。

7 最終

この演算子は、ソースObservableによって発行された最後の値を提供します。

8 ignoreElements

この演算子は、ソースObservableからのすべての値を無視し、コールバック関数を完了するかエラーにするための呼び出しのみを実行します。

9 サンプル

この演算子は、ソースObservableからの最新の値を提供し、出力は、渡された引数が出力するかどうかによって異なります。

10 スキップ

この演算子は、入力として取得されたカウント項目の最初の出現をスキップするオブザーバブルを返します。

11 スロットル

この演算子は、引数として使用される入力関数によって決定された時間、監視可能なソースからの値を出力するだけでなく無視し、同じプロセスが繰り返されます。

ユーティリティオペレーター

以下は、ユーティリティ演算子のカテゴリで説明する演算子です。

シニア番号 オペレーターと説明
1 タップ

この演算子は、ソースのオブザーバブルと同じ出力を持ち、オブザーバブルからユーザーに値をログに記録するために使用できます。主な値、エラーがある場合、またはタスクが完了した場合。

2 ディレイ

この演算子は、指定されたタイムアウトに基づいて、ソースObservableから発行された値を遅延させます。

3 delayWhen

この演算子は、入力として取得された別のオブザーバブルからのタイムアウトに基づいて、ソースオブザーバブルから発行された値を遅延させます。

4 observeOn

入力スケジューラに基づくこの演算子は、ソースObservableからの通知を再送信します。

5 subscribeOn

この演算子は、入力として取得されたスケジューラーに基づいて、ソースObservableへの非同期サブスクライブを支援します。

6 時間間隔

この演算子は、現在の値と、取得したスケジューラ入力を使用して計算された現在の値と前の値の間の経過時間を含むオブジェクトを返します。

7 タイムスタンプ

タイムスタンプを、値が発行された時刻を示すソースObservableから発行された値とともに返します。

8 タイムアウト

指定されたタイムアウト後にソースObservableが値を出力しない場合、この演算子はエラーをスローします。

9 toArray

Observableからすべてのソース値を累積し、ソースが完了するとそれらを配列として出力します。

条件付き演算子

以下は、条件演算子のカテゴリで説明する演算子です。

シニア番号 オペレーターと説明
1 defaultIfEmpty

ソースオブザーバブルが空の場合、この演算子はデフォルト値を返します。

2 すべて

入力関数がソースObservableの各値の条件を満たすことに基づいてObservableを返します。

3 見つける

これにより、ソースObservableの最初の値が、入力として取得された述語関数の条件を満たす場合に、observableが返されます。

4 findIndex

入力スケジューラに基づくこの演算子は、ソースObservableからの通知を再送信します。

5 isEmpty

この演算子は、入力オブザーバブルが値を出力せずに完全なコールバックに進む場合はtrueとして出力を返し、入力オブザーバブルが値を出力する場合はfalseとして出力を返します。

マルチキャスト演算子

以下は、マルチキャスト演算子カテゴリで説明する演算子です。

シニア番号 オペレーターと説明
1 マルチキャスト

マルチキャストオペレーターは、作成された単一のサブスクリプションを他のサブスクライバーと共有します。マルチキャストが取り込むパラメータは、connect()メソッドを持つConnectableObservableを返すサブジェクトまたはファクトリメソッドです。サブスクライブするには、connect()メソッドを呼び出す必要があります。

2 公開する

この演算子はConnectableObservableを返し、connect()メソッドを使用してオブザーバブルをサブスクライブする必要があります。

3 publishBehavior

publishBehaviourはBehaviourSubjectを利用し、ConnectableObservableを返します。作成されたオブザーバブルをサブスクライブするには、connect()メソッドを使用する必要があります。

4 publishLast

publishBehaviourはAsyncSubjectを利用し、ConnectableObservableを返します。作成されたオブザーバブルをサブスクライブするには、connect()メソッドを使用する必要があります。

5 publishReplay

publishReplayは、動作サブジェクトを利用して、値をバッファリングし、同じものを新しいサブスクライバーに再生して、ConnectableObservableを返します。作成されたオブザーバブルをサブスクライブするには、connect()メソッドを使用する必要があります。

6 シェア

これはmutlicast()演算子のエイリアスですが、唯一の違いは、サブスクリプションを開始するためにconnect()メソッドを手動で呼び出す必要がないことです。

エラー処理演算子

以下は、エラー処理演算子のカテゴリで説明する演算子です。

シニア番号 オペレーターと説明
1 catchError

この演算子は、新しいObservableまたはエラーを返すことにより、ソースObservableのエラーをキャッチします。

2 リトライ

このオペレーターは、エラーが発生した場合にソースObservableで再試行し、指定された入力カウントに基づいて再試行が行われます。