嗨,我有一个父窗体控件和一个子组件。在父窗体控件更改后才会显示子组件,例如:
<div *ngIf="parentControlChanged">
<ChildComponent [value]="parentChanged$ | async"></ChildComponent>
</div>如您所见,子组件使用一个async管道从父控件获取值(在这里,parentControlChanged是一个布尔状态,指示父控件首先被更改,而parentChanged$只是parentControl.valueChanges的管道,与这个问题无关)。
问题是在父控件更改后才显示子组件,因此尚未订阅valueChanges,因此无法获得父控件的更改值。否则,子组件将在显示父控件后获取其父控件的每个后续更改值。
那么,子组件在使用valueChanges管道订阅async之后,是否可以获得父控件的最新/当前值,就像订阅BehaviorSubject一样
发布于 2022-05-19 03:04:25
如果其他的东西已经订阅了parentChanged$,那么,除了您没有进入的副作用之外,在它的末尾使用管道shareReplay(1)。
然后,只要parentChanged$已经被订阅,当子组件或其他组件订阅它时,它最初将得到最后发出的值,任何副作用仍然只执行一次,而不是每个订阅者一次。
如果parentChanged$尚未订阅,则必须始终订阅并执行上述操作,或者更改为一种模式,在这种模式中,您可以将xyz.valueChanges更改为concat(defer(() => of(xyz.value)), xyz.valueChanges),以便在订阅时,它以要发送的初始值开始,然后发送更改。
https://stackoverflow.com/questions/72297900
复制相似问题