質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

AngularJS

AngularJSはオープンソースのJavaScriptフレームワークです。ブラウザ上で動作するウェブアプリケーションの開発にMVCアーキテクチャを取り入れることを目的としています。

Q&A

解決済

2回答

3887閲覧

非同期でAPIをループしてコールした後、全てのレスポンスを待って処理したい

rook

総合スコア13

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

AngularJS

AngularJSはオープンソースのJavaScriptフレームワークです。ブラウザ上で動作するウェブアプリケーションの開発にMVCアーキテクチャを取り入れることを目的としています。

0グッド

0クリップ

投稿2016/02/13 07:19

編集2016/02/17 11:24

typescriptでangularJSを書き、以下のようにforでループし、postして全てのレスポンスを待って処理させようとしています。ですが、2回目以降のループが動いていないようです。for文の中身を適当なログ出力に帰ると動くため、for文の問題ではないと思っています。何が問題なのかご教授ください。

typescript

1 2for (var key in values) { 3 var data = { 4 jsonrpc: '2.0', 5 id: 1, 6 auth: authId, 7 method: 'item.get', 8 params: { 9 'hostids': hostid, 10 'filter' : graphs[key].filter 11 } 12 }; 13 return this.$http.post(this.apiHost, data) 14 .then((response: any): any => { 15 if (key === (values.length - 1).toString()) { 16 return response.data; 17 } 18 }) 19 .catch((error: any): any => { 20 this.$log.error('Failed for init.¥n', error.data); 21 }); 22} 23

}

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

最初に、僕は angular 使いじゃないので、 angular に関する基礎知識は何もありません。
一般的な Promise パターンや JavaScript の非同期処理・イベント駆動型プログラミングの知識で書きます。

所感で恐縮ですが、非同期処理やスコープチェーンの挙動についてもっと深い理解が必要そうです。

this.$http.postを複数回実行しなければいけないのですよね。
ですが、最初に実行した段階でreturnされているので、for 文は最初のループで必ず終了し、リクエストは一度しか投げられません。
修正された場所ではなく、以下の行の話です。
return this.$http.post(this.apiHost, data)// 無条件に return

次に、keyvalues.lengthと比較していますが、この比較は不毛です。
これは非同期処理なので、then に渡されたコールバック関数が実行されるときにはすでに for 文のループは終了しているはずです。つまりこの時点ではkeyは絶対にvalues.length - 1と等しいので、比較しても無駄です。(最初の問題を解決したあとの話です。)

さらに、等しかった場合に return していますが、これはあくまで then コールバックから return しているだけで、これによって外側の大きなループから抜けることはありません。(と言うか上記の通りすでに抜けたあとの話なので今更 return どうこうの問題ではありません。)

解決するためには、以下のページの「$q.all() メソッドによる複数 Promise オブジェクトの監視」の章までを理解する必要がありそうです。これがまさしくやりたいことではないでしょうか。
[AngularJS] $q サービスで覚える Promise | Developers.IO

投稿2016/03/19 15:59

tozjp

総合スコア790

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

rook

2016/03/27 05:15

ご丁寧なありがとうございます。おっしゃる通り理解不足みたいなので、教えていただいた内容を中心に勉強してみます。
guest

0

一個目の postが終わった後で、return しちゃってますよ。

return this.$http.post(this.apiHost, data)

投稿2016/02/15 02:39

katsumiy

総合スコア479

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

rook

2016/02/17 11:26

大変失礼しました。ソースコードに誤りがありました。 以下のようにreturnの前にループが想定回数回っているかどうかの判定文を入れています。それなのに2回目のループが動かない状況です。何か気づくところがありましたらご教授ください。 if (key === (values.length - 1).toString()) { return response.data; }
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問