Я пытаюсь программно установить значение 2 полей <input matInput>
abnd <mat-select>
. Для ввода текста все работает должным образом, однако для <mat-select>
в представлении это поле выглядит так же, как и значение null
. Но если я позвоню console.log(productForm.controls['category'].value
, он распечатает правильное значение, которое я установил программно. Я что-то упускаю?
Вот код:
конфигурация формы:
productForm = new FormGroup({
name: new FormControl('', [
Validators.required
]),
category: new FormControl('', [
Validators.required
]),
});
значение настройки:
ngOnInit() {
this.productForm.controls['name'].setValue(this.product.name);
this.productForm.controls['category'].setValue(this.product.category);
}
}
html:
<mat-form-field>
<mat-select [formControlName]="'category'"
[errorStateMatcher]="errorStateMatcher">
<mat-option *ngFor="let category of categories" [value]="category">
{{category.name}}
</mat-option>
</mat-select>
</mat-form-field>