首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在订阅前获得窗体控件valueChanges值?

如何在订阅前获得窗体控件valueChanges值?
EN

Stack Overflow用户
提问于 2022-05-19 02:11:02
回答 1查看 528关注 0票数 0

嗨,我有一个父窗体控件和一个子组件。在父窗体控件更改后才会显示子组件,例如:

代码语言:javascript
运行
复制
<div *ngIf="parentControlChanged">
  <ChildComponent [value]="parentChanged$ | async"></ChildComponent>
</div>

如您所见,子组件使用一个async管道从父控件获取值(在这里,parentControlChanged是一个布尔状态,指示父控件首先被更改,而parentChanged$只是parentControl.valueChanges的管道,与这个问题无关)。

问题是在父控件更改后才显示子组件,因此尚未订阅valueChanges,因此无法获得父控件的更改值。否则,子组件将在显示父控件后获取其父控件的每个后续更改值。

那么,子组件在使用valueChanges管道订阅async之后,是否可以获得父控件的最新/当前值,就像订阅BehaviorSubject一样

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-05-19 03:04:25

如果其他的东西已经订阅了parentChanged$,那么,除了您没有进入的副作用之外,在它的末尾使用管道shareReplay(1)

然后,只要parentChanged$已经被订阅,当子组件或其他组件订阅它时,它最初将得到最后发出的值,任何副作用仍然只执行一次,而不是每个订阅者一次。

如果parentChanged$尚未订阅,则必须始终订阅并执行上述操作,或者更改为一种模式,在这种模式中,您可以将xyz.valueChanges更改为concat(defer(() => of(xyz.value)), xyz.valueChanges),以便在订阅时,它以要发送的初始值开始,然后发送更改。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72297900

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档