angular - 在 Angular 中将异步数据从父级传递给子级

标签 angular firebase angularfire2

使用 Angularfire2,我试图将从 Firebase 数据库中检索到的对象从父级传递给子级:

家长:

@Component({
  selector: 'app-page',
  styleUrls: ['./page.component.scss'],
  template: `
    <app-page-render [page]="page"></app-page-render>
  `,
})
export class PageComponent implements OnInit {
  slug: string;
  page: FirebaseObjectObservable<Page>;

  constructor(private af: AngularFire, private route: ActivatedRoute) {
  }

  ngOnInit() {
    this.route.params
      .switchMap((params: any) => this.af.database.object(`/pages/${params['page-slug']}`))
      .subscribe(page => this.page = page);
  }

}

child :

@Component({
  selector: 'app-page-render',
  styleUrls: ['./page-render.component.scss'],
  template: `
   <div class="page-header">
      <div class="page-banner">
        <picture>
          <source [srcset]="page.header.desktop" media="(min-width: 1024)">
          <source [srcset]="page.header.tablet" media="(min-width: 768px)">
          <img [src]="page.header.mobile" [alt]="page.header.alt" class="page-banner--image">
        </picture>
        <h1 class="page-banner--heading">{{page.header.title}}</h1>
      <div>
    </div>
    <main class="main-container">
      <div [innerHTML]="page.content"></div>
    </main>
  `
})
export class PageRenderComponent implements OnInit {
  @Input()
  page: any;

  constructor() { }

  ngOnInit() {
  }

}

当然,这给了我“ header 未定义”,因为 child 在呈现之前解析数据。我可以添加(页面 | 异步)吗?到所有变量,但这意味着在一个模板中有一堆异步调用,我理解这不是很好的做法。

将异步数据从父级传递给子级有什么最佳实践吗?我已经看到在某些地方使用了 ngOnChanges,但我也不确定这是否是正确的策略。

最佳答案

你可以使用

<div class="page-header" *ngIf="page">

或安全导航运算符(operator)

<source [srcset]="page?.header?.desktop" media="(min-width: 1024)">

关于angular - 在 Angular 中将异步数据从父级传递给子级,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42586224/

相关文章:

javascript - 找不到模块 '@angular-devkit/schematics/tasks'

ajax - Angular 2 HTTP 进度条

javascript - 重构此方法以将其认知复杂度从 21 降低到允许的 15。如何重构和降低复杂度

android - 无法解析 Firebase Storage getDownloadUrl() 方法

javascript - 我的提交帖子功能无法使用

Angular 2 AuthGuard + Firebase 身份验证

css - Angular-material:input-group 和 md-buttons 在同一行

javascript - 我可以在 Firebase 身份验证中验证电子邮件的域区域吗?

javascript - 不能在 firebase(ionic) 中使用变量作为 angularfire2 列表名称

angular - firestore 中的 snapshotchanges 是什么