我有一个仅在observable
有数据时才显示信息的组件。但是当我尝试在async
上使用observable
运算符时,我看不到任何值。我对异步管道的工作方式感到困惑,我认为初始化可观察对象会花费一些时间,在这种情况下,async pipe
不会对未定义的可观察对象执行任何操作,这就是该组件未显示的原因。
@Component({
template: `
<div *ngIf="todo$ | async as todo">
<div {{todo.name}} </div>
</div>
`
})
export class TodosComponent implements OnInit,OnDestroy {
todo$: Observable<Todo>;
constructor(private store: Store<State>) {}
ngOnInit() {
this.todo$ = this.store
.pipe(select(selectTodos));
}
ngOnDestroy(): void {
}
}
我知道async
管道将处理Observable
,但是如果Observable仍然 undefined 会怎样,异步管道也将处理该情况。如果是这样,则对我可能做错的事情有任何建议,请注意,我已订阅并检查observable是否有数据。