私の反応性フォームは、3つのコンポーネントレベルの深いです。親コンポーネントはフィールドを持たない新しいフォームを作成し、子コンポーネントに渡します。動的ネストされた反応形式:ExpressionChangedAfterItHasBeenCheckedError
最初は外側の形式が有効です。後で子コンポーネントは、外部フォームを無効にするバリデーター(失敗した)を含む新しいフォーム要素を追加します。
私はコンソールにExpressionChangedAfterItHasBeenCheckedErrorエラーを取得しています。私はそのエラーを修正したい。
これはどういうわけか、これはネストの3番目のレベルを追加したときにのみ発生します。同じアプローチが、2つのレベルの入れ子で機能するように見えました。
Plunker:https://plnkr.co/edit/GymI5CqSACFEvhhz55l1?p=preview
親コンポーネント
@Component({
selector: 'app-root',
template: `
myForm.valid: <b>{{myForm.valid}}</b>
<form>
<app-subform [myForm]="myForm"></app-subform>
</form>
`
})
export class AppComponent implements OnInit {
...
ngOnInit() {
this.myForm = this.formBuilder.group({});
}
}
サブコンポーネント
@Component({
selector: 'app-subform',
template: `
<app-address-form *ngFor="let addressData of addressesData;"
[addressesForm]="addressesForm">
</app-address-form>
`
})
export class SubformComponent implements OnInit {
...
addressesData = [...];
constructor() { }
ngOnInit() {
this.addressesForm = new FormArray([]);
this.myForm.addControl('addresses', this.addressesForm);
}
子コンポーネント
@Component({
selector: 'app-address-form',
template: `
<input [formControl]="addressForm.controls.addressLine1">
<input [formControl]="addressForm.controls.city">
`
})
export class AddressFormComponent implements OnInit {
...
ngOnInit() {
this.addressForm = this.formBuilder.group({
addressLine1: [
this.addressData.addressLine1,
[ Validators.required ]
],
city: [
this.addressData.city
]
});
this.addressesForm.push(this.addressForm);
}
}
チェック[あなたは 'ExpressionChangedAfterItHasBeenCheckedError'エラーについて知る必要があるすべてのもの](https://blog.angularindepth.com/everything-you-need-to-know-about-the-expressionchangedafterithasb eencheckederror-error-e3fd9ce7dbb4)記事 –
私はそのページを過去24時間で5回訪問しました;)まだそれを修正する方法はまだ分かりません。 –
あなたが参照したプランナーにエラーはありません –