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

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

ただいまの
回答率

90.51%

  • Firebase

    904questions

    Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

  • Onsen UI

    354questions

    HTML5で記述されたモバイルアプリの高速化、およびネイティブアプリライクなUIが作れるフレームワーク。 様々なJavaScriptフレームワークと併せて使用することができます。スマートフォン向けアプリ、Webサイトに必要なアニメーション、UI/UXを実装することが可能になります。

  • Angular2

    191questions

【Angular2 Firebase】ngForでストレージにある画像を取得したい

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 1,138

KoheiOkazaki

score 34

現在Angular2とFirebaseを使ったアプリ開発を行っています。

ユーザー一覧の画面があるのですが、そこをngForを使って取得しています。

    <ons-list-item class="list__item list__item--chevron" tappable *ngFor="let request of requests | async" (click)="pushToDetail(request)">
        <ons-row>
          <ons-col width="20%"><img [src]="userProfileImg"></ons-col>
          <ons-col style="padding-left:20px;">
            <p class="stars">★★★★★</p>
            <p class="name"><i class="fa fa-venus fa-fw" aria-hidden="true"></i>{{request.nickName}}</p>
            <p class="time"><i class="fa fa-clock-o fa-fw" aria-hidden="true"></i>{{request.startingTime | date:'MM'}}/{{request.startingTime | date:'dd'}}/{{request.startingTime | date:'hh:mm'}}</p>
            <p class="time label" style="background-color:#57c1ff;">{{request.serviceTime}}</p>
            <p class="km">1.3km</p>
          </ons-col>
        </ons-row>
    </ons-list-item>

imageに関してはstorageにアクセスして取得しています。

getProfileImageUrl(userId: string) {
    const userStorageRef = firebase.storage().ref().child('images/users/' + userId + "_users.jpg");
    userStorageRef.getDownloadURL().then(url => {
      this.userProfileImg = url
    });
  }

ただ、これだと最後のユーザーの画像を取得してforで回すので正しくありません。どうやってfor文を使ってstorageにアクセスするのでしょうか?

上記のメソッドを使ってforで回すのはできなかったです。(Monacaが落ちます)

<ons-col width="20%"><img [src]="getProfileImageUrl(userId)"></ons-col>

どうぞよろしくお願いいたします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

+1

request.userProfileImg以外の要素をどのように取得しているのかが分からないのですが、request.userProfileImgは非同期通信で取得しているのですね。エラーメッセージが無いため推測となりますが、Monacaが落ちる理由は恐らく*ngForの中で非同期通信を何度も発生させている関連ではないかと。
アプローチとしては、*ngForの要素内では単にrequest.userProfileImgと記述しておいて、requestに対しuserProfileImgを設定する際に非同期通信を発生させるのが良いかと思います。

<ons-col width="20%"><img [src]="getProfileImageUrl(userId)"></ons-col>


↓修正後

<ons-col width="20%"><img [src]={{request.userProfileImg}}></ons-col>

上記のようにHTML上には記載しておいて、JavaScript側で任意のタイミングでrequest.userProfileImgを設定するようにしておけばよいのではないでしょうか。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/12/27 01:10

    ご回答どうもありがとうございます!

    キャンセル

check解決した方法

0

かなり微妙な方法ですが自己解決できました。

akabeeさまのおっしゃるとおり、ストレージからgetDownLoadさせると処理が相当重たいみたいでMonacaが落ちてしまうのでfirebaseストレージのURLをベタ書きする方法でとってくるようにしました(汗)

URL+該当パスの形でとってこれればfor文でも回せるようです。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

同じタグがついた質問を見る

  • Firebase

    904questions

    Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

  • Onsen UI

    354questions

    HTML5で記述されたモバイルアプリの高速化、およびネイティブアプリライクなUIが作れるフレームワーク。 様々なJavaScriptフレームワークと併せて使用することができます。スマートフォン向けアプリ、Webサイトに必要なアニメーション、UI/UXを実装することが可能になります。

  • Angular2

    191questions