这是一个关于如何在Angular中使用响应式表单来添加组控件数组的解决方法的示例代码:
首先,需要在Angular项目中导入FormsModule和ReactiveFormsModule模块。
app.module.ts文件:
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
import { AppComponent } from './app.component';
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule,
FormsModule,
ReactiveFormsModule
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }
接下来,我们可以在组件的模板文件中创建一个表单,并使用FormArray来添加组控件数组。
app.component.html文件:
在组件的类文件中,我们需要创建一个FormGroup和FormArray,并提供初始值和验证规则。
app.component.ts文件:
import { Component, OnInit } from '@angular/core';
import { FormBuilder, FormGroup, FormArray, Validators } from '@angular/forms';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent implements OnInit {
myForm: FormGroup;
constructor(private fb: FormBuilder) { }
ngOnInit() {
this.myForm = this.fb.group({
users: this.fb.array([])
});
this.addUser();
}
get users() {
return this.myForm.get('users') as FormArray;
}
addUser() {
const user = this.fb.group({
name: ['', Validators.required],
email: ['', [Validators.required, Validators.email]]
});
this.users.push(user);
}
}
在上面的代码中,我们首先使用FormBuilder创建了一个名为myForm的FormGroup,并使用FormArray创建了一个名为users的数组控件。然后,在ngOnInit方法中,我们调用addUser方法来添加一个初始的用户组。
在addUser方法中,我们使用fb.group创建了一个名为user的新FormGroup,该组包含了name和email的控件,并将该组添加到users数组控件中。
最后,在模板中,我们使用*ngFor循环遍历users.controls数组,并使用formGroupName绑定每个用户组的索引。这样,我们就可以在模板中显示和操作用户组的控件了。
希望这个示例代码可以帮助到你!