要解决“Angular 7 响应式 - 动态添加到 FormArray 的下拉菜单显示错误太快”的问题,可以使用 debounceTime 操作符来延迟下拉菜单显示。下面是一个示例代码:
首先,在组件的构造函数中导入 FormControl、FormArray、debounceTime 和 FormGroup:
import { Component, OnInit } from '@angular/core';
import { FormControl, FormGroup, FormArray } from '@angular/forms';
import { debounceTime } from 'rxjs/operators';
然后,在组件类中定义一个 FormGroup 和一个 FormArray:
export class YourComponent implements OnInit {
formGroup: FormGroup;
formArray: FormArray;
ngOnInit() {
this.formGroup = new FormGroup({
options: new FormArray([])
});
this.formArray = this.formGroup.get('options') as FormArray;
}
}
接下来,我们可以添加一个方法来动态添加下拉菜单项,并在添加时应用 debounceTime 操作符:
addOption() {
const control = new FormControl('');
control.valueChanges.pipe(debounceTime(500)).subscribe(value => {
console.log(value); // 在此处可以执行其他逻辑,例如发送 HTTP 请求等
});
this.formArray.push(control);
}
在这个例子中,我们使用了 debounceTime(500) 来延迟显示下拉菜单的选项。可以根据实际需求调整延迟时间。
最后,在模板中添加一个按钮来触发添加下拉菜单项的方法:
这样,当用户点击按钮添加下拉菜单项时,下拉菜单的选项会延迟显示,从而解决了显示错误太快的问题。
希望这个解决方案对你有帮助!