0

数据库:火力基地

用户可以添加一个看起来有点像的帖子:

postKey
  content: 'Content of the post',
  date: 'Date of post',
  author: 'authorKey' (author key is a login)

我认为我不应该将所有用户信息存储在其中author,因为用户有一天会更改他的个人资料中的某些内容。我只在里面存储用户密钥author,我想在视图内打印帖子数据时获取该用户。

(服务)这就是我获取所有帖子的方式(正常工作)

  getPosts(): Promise<any> {
    return new Promise(
      (resolve) => {
        this.af.database.list('/posts')
          .subscribe(response => {
            if(response.length > 0) resolve(response);
          })
      }
    )
  }

(组件)在这里,我只是将所有这些帖子分配给帖子数组以在视图中打印它。

  posts: any;

  constructor(private homepageService: HomepageService) {
    homepageService.getPosts().then(
      response => {
        this.posts = response.reverse();
      });
  }

(查看)除了我可以很容易打印的所有帖子数据外,我想通过 post.author 让用户打印照片、名字、姓氏等作者数据。

<div *ngFor="let post of posts" class="post-body">
    {{post.content}}
    {{homepageService.getUser(post.author)?.email}}
</div>

这样我想得到用户。这是getUser函数

  getUser(key): Promise<any> {
    return new Promise(
      (resolve) => {
        this.af.database.object('/users/' + key)
          .subscribe(response => {
            resolve(response);
          })
      }
    );
  }

我知道那条线是错误{{homepageService.getUser(post.author)?.email}}的,没有then内部视图,但我也尝试过使用异步管道。现在我处于停滞状态。我该怎么做?

4

1 回答 1

1
{{(homepageService.getUser(post.author) | async)?.email}}

或者

{{(homepageService.getUser(post.author) | async).email}}

  getUser(key): Observable<any> {
    return this.af.database.object('/users/' + key);
  }
于 2016-08-03T11:34:18.463 回答