Angular 更改子窗体值后,不会更新父窗体值
我有一个嵌套表单。我使用Angular 更改子窗体值后,不会更新父窗体值,angular,typescript,angular-reactive-forms,Angular,Typescript,Angular Reactive Forms,我有一个嵌套表单。我使用patchValue初始化子表单。这里的许多人可能会问,为什么我在创建新表单时没有将子表单字段设置为默认值,答案是子表单需要从RESTAPI初始化,但在示例代码中,我只是使用patchValue来演示我的问题 ngOnInit() { this.form = new FormGroup({ input: new FormControl("", [Validators.required, Validators.maxLength(5)
patchValue
初始化子表单。这里的许多人可能会问,为什么我在创建新表单时没有将子表单字段设置为默认值,答案是子表单需要从RESTAPI初始化,但在示例代码中,我只是使用patchValue
来演示我的问题
ngOnInit() {
this.form = new FormGroup({
input: new FormControl("", [Validators.required, Validators.maxLength(5)])
});
this.form.patchValue({
input: "test"
});
this.form.valueChanges
.pipe(untilDestroyed(this))
.subscribe((value: string) => {
this.onChangeFunc(value);
});
}
请参考我的示例代码:
问题:子窗体值已初始化(状态有效),但父窗体值仍然为空(状态无效)
任何关于以下方面的建议都将不胜感激:在子表单值通过
patchValue
或setValue
更新后,如何正确更新父表单值?在订阅form.valueChanges和注册表中onChangeFunc初始化后,补丁值似乎可以工作。这样地