Fur*_*oud 5 angular-material angular angular6
假设我具有以下表单结构:
this.myForm = this.formBuilder.group({
date: ['', [Validators.required]],
notes: [''],
items: this.initItems()
});
initItems() {
var formArray = this.formBuilder.array([]);
for (let i = 0; i < 2; i++) {
formArray.push(this.formBuilder.group({
name: ['', [Validators.required]],
age: ['', [Validators.required]],
}));
}
return formArray;
}
Run Code Online (Sandbox Code Playgroud)
并且名称控件应该是自动完成的,如何将所有名称控件与自动完成列表相关联?
我通过将name内部的每个控件FormArray与一个filteredOption数组相关联来解决了这个问题:
ManageNameControl(index: number) {
var arrayControl = this.myForm.get('items') as FormArray;
this.filteredOptions[index] = arrayControl.at(index).get('name').valueChanges
.pipe(
startWith<string | User>(''),
map(value => typeof value === 'string' ? value : value.name),
map(name => name ? this._filter(name) : this.options.slice())
);
}
Run Code Online (Sandbox Code Playgroud)
然后,每次formgroup在form Array(create new item)内部构建一个内部之后,我需要像这样在新索引处调用上述函数:
addNewItem() {
const controls = <FormArray>this.myForm.controls['items'];
let formGroup = this.formBuilder.group({
name: ['', [Validators.required]],
age: ['', [Validators.required]],
});
controls.push(formGroup);
// Build the account Auto Complete values
this.ManageNameControl(controls.length - 1);
}
Run Code Online (Sandbox Code Playgroud)
在.html文件中,我们需要引用所需的filteredOption数组,我们可以通过使用i索引来做到这一点:
<mat-option *ngFor="let option of filteredOptions[i] | async " [value]="option">
{{ option.name }}
</mat-option>
Run Code Online (Sandbox Code Playgroud)
请在这里查看详细答案https://stackblitz.com/edit/angular-szxkme?file=app%2Fautocomplete-display-example.ts
| 归档时间: |
|
| 查看次数: |
2435 次 |
| 最近记录: |