AngularFire-在模板中显示FireStorage中的图像

时间:2019-12-21 17:52:34

标签: angular firebase-realtime-database firebase-storage angularfire2

我有由Firebase数据库支持的Angular Web应用程序。数据库中的每个元素代表一个图像数据。除了图像的元数据,元素中的一个关键是图像的FirebaseStorage位置。

需要遍历模板中的图像元素,显示元数据和显示图像。

服务正在负责返回实时数据库数据。然后,组件类的方法负责为FirebaseStorage返回图像URL。这是Angularfire个文档,用于检索图片的网址。

需要帮助,使用数据库元素返回的动态数据检索图像的url。

这是我组件的.ts文件:

import { AngularFireStorage } from '@angular/fire/storage';
import { DataService } from './data.service';
import { Observable } from 'rxjs';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})

export class AppComponent {
  public charts: Observable<any[]>;
  public imgSrc: Observable<string | null>;

  constructor(private DS: DataService, 
    private st: AngularFireStorage) { }

  ngOnInit () {
    this.charts = this.DS.getCharts();
  }

  getImg(imgSrcRaw: string) {
    const ref = this.st.ref(imgSrcRaw);
    this.imgSrc = ref.getDownloadURL();
    return this.imgSrc;
  }
}

data.service.ts:

import { Injectable } from '@angular/core';
import { AngularFireDatabase } from '@angular/fire/database';
import { Observable } from 'rxjs';

@Injectable()
export class DataService {
    charts: Observable<any[]>;

    constructor(private db: AngularFireDatabase) { 
        this.charts = this.db.list('horizontals_1').valueChanges();
    }

    getCharts() : Observable<any[]> {
        return this.charts;
    }

模板:

<div *ngFor="let chart of charts | async">
    <p>{{ chart.symbol }}/{{ chart.comp_symbol }} </p>
    <img [src]="getImg( chart.img_src )" />
</div>

PS:我是Angular的新手,解决方法可能很简单。

PS2:还可以直接在Constructor中检索图像的url。但是我不知道如何检索Observable数组的一个元素的特定键。

感谢帮助!

1 个答案:

答案 0 :(得分:0)

尝试类似的操作:

<div *ngFor="let chart of charts | async">
    <p>{{ chart.symbol }}/{{ chart.comp_symbol }} </p>
    <img src="{{getImg( chart.img_src )}}" />
</div>

在您的组件中。

import { AngularFireStorage } from '@angular/fire/storage';
import { DataService } from './data.service';
import { Observable } from 'rxjs';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})

export class AppComponent {
  public charts: Observable<any[]>;
  public imgSrc: any; // Change imgSrc type

  constructor(private DS: DataService, 
    private st: AngularFireStorage) { }

  ngOnInit () {
    this.charts = this.DS.getCharts();
  }

  getImg(imgSrcRaw: string) {
    let ref = this.st.ref(imgSrcRaw);
    this.imgSrc = ref.getDownloadURL();
    return this.imgSrc;
  }
}