###ご意見いただきたいこと
RxJSとAngularのHttpClientを使用して、複数のHTTPリクエストを逐次的に実行(ひとつめのAPIにリクエストを投げて、200でレスポンスが帰ってきたら、二つ目のAPIにリクエストを投げる)する適切な方法がわからないので、RxJSに詳しいかたにご教示いただければと思い書き込みました。
とくに以下に2点について教えていただければいただければと思います。
-
Promiseで書いた以下のような処理を、RxJSでどのようにかくのか。
あるいは、こういったことをする場合は、AngularでもRxJSを使わず Promise あるいは async await を使用して書くのが一般的なのか。 -
"試したこと" のコードで mergeMap を do に置き換えた場合になぜ2つ目のURLに対してリクエストが投げられないのか
apiA() // 一つ目のAPIにリクエストを投げるPromiseを返す関数 .then((response) => { // 一つ目のAPIの結果をみてなにか処理 return apiBPromise(); // 2つ目のAPIにリクエストを投げるPromiseを返す関数 }) .then((response) => { // 二つ目のAPIの結果を参照してなにか処理 });
###試したこと
一応以下のように mergeMap メソッド(古いバージョンではflatMap)を使用して、やりたいことはできているのですが、
メソッド名から察するに本来こういう用途で使うものでは無い気がしてなりません。
RxJSに do メソッドというものがあるのも知ったので、下記コードの mergeMap を do に置き換えたところ、
一つ目のAPIのURLにはリクエストが投げられるのですが、2つめのAPIのURLにはリクエストが投げられません。
// this.httpClient は @angular/common/http の HttpClientのインスタンスです。 this.httpClient.post('【一つ目APIのURL】') .mergeMap(() => this.httpClient.get('【二つ目APIのURL】')) .subscribe( response => { // 2つ目のAPIのレスポンスをみてなにか処理 } );
###補足情報(言語/FW/ツール等のバージョンなど)
-
RxJSのバージョン: 5.5.6
-
Angularのバージョン: 5 (Angular CLI 1.6.3 を使用して作成したプロジェクトです。)
-
Node.jsのバージョン: v8.9.4
-
npmのバージョン: 5.6.0
-
開発マシンのOS macOS Sierra
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2018/01/17 03:37