在Angular中,当我们处理动态表单时,有时需要将一个表单组中的FormControl更改为动态创建的表单控件数组。这在当我们需要实现添加或删除动态表单控件时尤其有用。
以下是通过将表单控件数组转换为动态FormGroup的代码示例:
首先,定义表单控件数组,如下所示:
const formControls: FormControl[] = [ new FormControl('', Validators.required), new FormControl('', Validators.required), new FormControl('', Validators.pattern(/\S+@\S+.\S+/)) ];
接下来,将表单控件数组转换为动态FormGroup,如下所示:
const dynamicFormGroup: FormGroup = new FormGroup({});
formControls.forEach((control, index) => {
dynamicFormGroup.addControl(control-${index + 1}
, control);
});
最后,添加动态FormGroup到父级FormGroup中,如下所示:
this.parentFormGroup.addControl('dynamicFormGroup', dynamicFormGroup);
现在,我们已将表单控件数组转换为动态FormGroup,可以在需要时添加或删除表单控件。
下面是完整的代码示例:
import { Component, OnInit } from '@angular/core'; import { FormControl, Validators, FormGroup } from '@angular/forms';
@Component({ selector: 'app-dynamic-form', templateUrl: './dynamic-form.component.html' }) export class DynamicFormComponent implements OnInit { parentFormGroup: FormGroup;
ngOnInit() { const formControls: FormControl[] = [ new FormControl('', Validators.required), new FormControl('', Validators.required), new FormControl('', Validators.pattern(/\S+@\S+.\S+/)) ];
const dynamicFormGroup: FormGroup = new FormGroup({});
formControls.forEach((control, index) => {
dynamicFormGroup.addControl(`control-${index + 1}`, control);
});
this.parentFormGroup = new FormGroup({
dynamicFormGroup: dynamicFormGroup
});
}
addControl() { const control: FormControl = new FormControl('', Validators.required); const index = this.parentFormGroup.get('dynamicFormGroup').length