对整个块使用异步管道和可观察的

Ben*_*wis 3 typescript angular

我有一个 Observable,它从 API 返回一个大对象。我需要在我的模板中显示这些值。

对于以数组形式返回的其他数据,我可以使用:

<div *ngFor="let value of values | async">
  <p>{{ value.prop }}</p>
</div>
Run Code Online (Sandbox Code Playgroud)

我不需要等待异步在 中完成*ngFor,因为它的父元素中已经有一个异步管道。

对于我的对象,我正在寻找类似的东西。目前,我正在做类似的事情:

<h2>{{ (obj | async)?.title }}</h2>
<p>{{ (obj | async)?.prop.prop2 }}</p>
<p>{{ (obj | async)?.another.prop }}</p>
Run Code Online (Sandbox Code Playgroud)

这显然留下了很多重复的代码。这样的事情存在吗?

<div *using="obj | async">
  <!-- obj has resolved, can access obj.prop -->
</div>
Run Code Online (Sandbox Code Playgroud)

Jul*_*ova 7

使用“as”语法。

另请注意,每个异步管道都会创建一个新订阅,如果您的订阅使用 http - 这意味着多个 http 调用。如果您想在具有异步管道的模板中多次使用相同的可观察值,请使用 Rx share()。

     @Component({
      selector: 'my-app',
      template: `
        <div>
          <div *ngIf="obj$ | async as obj; else empty">
         {{obj.x}}
         {{obj.y}}
         </div>
         <ng-template #empty>Empty. Wait 5 s...</ng-template>
        </div>
      `,
    })
    export class App {
      s = new Subject();
      obj$;
      constructor() {
        this.obj$ = this.s.asObservable();
        setTimeout(() => {
          this.s.next({x:12, y:100});
        }, 5000)
      }
    }
Run Code Online (Sandbox Code Playgroud)

  • 您能否指出文档中“as”的记录位置? (5认同)
  • 这是 Angular 4 的新功能。我刚刚阅读了源代码。https://github.com/angular/angular/blob/master/packages/common/src/directives/ng_if.ts (2认同)