我已经创建了一个表单,我使用的是角形材质,并且可以在文本字段或textarea字段中成功获取并设置值,但无法在下拉菜单中输入值,我有两个json数据。第一个将填充下拉列表,第二个将设置下拉列表的值。所以在onload页面上,我必须在未设置的下拉列表中显示该值
createProductForm(): FormGroup {
return this._formBuilder.group({
CATEGORY: [this.product.categories]
});
}
ngOnInit() {
getAllCategory=[
{"TYPE_CODE": "CATEGORY","TYPE_DESC": "PUBLIC"},
{"TYPE_CODE": "CATEGORY","TYPE_DESC": "PRIVATE"},
{"TYPE_CODE": "CATEGORY","TYPE_DESC": "SYSTEM"},
]
defaultSelectCategory=[
{"CATEGORY": "PRIVATE"}
]
this.defaultCat= defaultSelectCategory[0].CATEGORY;
}
<mat-form-field appearance="outline" fxFlex="100">
<mat-label>Project</mat-label>
<mat-select formControlName="CATEGORY" [(value)]="defaultCat" required >
<mat-option *ngFor="let item of getAllCategory" value="{{item.TYPE_DESC}}" (onSelectionChange)="getCATEGORY(item)">
{{item.TYPE_DESC}}
</mat-option>
</mat-select>
<mat-icon matSuffix class="secondary-text">outlined_flag</mat-icon>
</mat-form-field>
不知道我无法为下拉Onload设置默认值。 非常感谢。顺便说一句,今天是我的生日,所以不要忘记祝我。 大声笑
答案 0 :(得分:1)
尝试使用ngModel
<div>
<mat-select [(ngModel)]="selected2">
<mat-option *ngFor="let option of options2" [value]="option.id">{{ option.name }}</mat-option>
</mat-select>
</div>
以及垫选项中带有方括号的值
答案 1 :(得分:0)
我可以在您的代码中看到很多问题,变量(getAllCategory,defaultSelectCategory)在ngOnInit()中声明,这是错误的。您需要在顶部声明它们,并使用'this'关键字在ngOnInit()中使用它。
我在这里创建了一个工作叉-https://stackblitz.com/edit/angular-5r6u3p-dhwgqm 看看吧。
DatePicker HTML
<mat-form-field appearance="outline" fxFlex="100">
<mat-label>Project</mat-label>
<mat-select [(value)]="defaultCat" required>
<mat-option *ngFor="let item of getAllCategory" value="{{item.TYPE_DESC}}"
(onSelectionChange)="getCATEGORY(item)">
{{item.TYPE_DESC}}
</mat-option>
</mat-select>
<mat-icon matSuffix class="secondary-text">outlined_flag</mat-icon>
DatePicker TS
export class DatepickerValueExample {
getAllCategory=[
{"TYPE_CODE": "CATEGORY","TYPE_DESC": "PUBLIC"},
{"TYPE_CODE": "CATEGORY","TYPE_DESC": "PRIVATE"},
{"TYPE_CODE": "CATEGORY","TYPE_DESC": "SYSTEM"},
]
defaultSelectCategory=[
{"CATEGORY": "PRIVATE"}
]
defaultCat;
ngOnInit() {
this.defaultCat= this.defaultSelectCategory[0].CATEGORY;
}
getCATEGORY() {
}
}
答案 2 :(得分:0)
所以首先,我建议几件事:
首先将您的默认值更改为一个对象,或者不重复您自己,您可以使用已有的相同数组进行操作:
this.defaultSelectCategory = this.getAllCategory[1];
现在,假设您的下拉formControlName是这样的:
CATEGORY: new FormControl(this.defaultSelectCategory.TYPE_DESC, [Validators.required]),
然后在您的HTML中:
<mat-form-field appearance="outline" fxFlex="100">
<mat-label>Project</mat-label>
<mat-select formControlName="CATEGORY">
<mat-option *ngFor="let item of getAllCategory" [value]="item.TYPE_DESC">
{{item.TYPE_DESC}}
</mat-option>
</mat-select>
<mat-icon matSuffix class="secondary-text">outlined_flag</mat-icon>