Как сделать динамическую форму в угловых 2
Я работаю с angular2, и мне нужно сделать динамическую форму, проблема в том, что во время отправки формы захватывает только последний из входных элементов. Я понимаю, что мне нужно преобразовать этот элемент в договоренность, но я не добился успеха
import { Component, OnInit } from '@angular/core';
import { Router, ActivatedRoute, Params } from '@angular/router';
import { InformeService } from './informe.service';
import { FormGroup, FormBuilder, Validators } from '@angular/forms';
declare var jQuery: any;
declare var $: any;
@Component({
selector: 'app-informe',
templateUrl: './informe.component.html',
styleUrls: ['./informe.component.css'],
providers: [InformeService]
})
export class InformeComponent implements OnInit {
objGeneralIndex: number = 1;
objGeneral = [{ id: 1, text: "" }];
objEspecificos = [{ id: 1, text: "" }];
objEspecificosIndex: number = 1;
formInforme: FormGroup;
constructor(
private route: ActivatedRoute,
private router: Router,
private service: InformeService,
private fb: FormBuilder
) { this.crearControles(); }
ngOnInit() { $("#infoBasic").show(500); $("#objGeneral").hide(500); $("#objEspec").hide(500); }
showInfoBasic() {
$("#infoBasic").show(500); $("#objGeneral").hide(500); $("#objEspec").hide(500);
}
showObjGral() {
$("#infoBasic").hide(500); $("#objGeneral").show(500); $("#objEspec").hide(500);
}
showObjEspec() {
$("#infoBasic").hide(500); $("#objGeneral").hide(500); $("#objEspec").show(500);
}
crearControles() {
this.formInforme = this.fb.group({
tituloInforme: '',
fechaInforme: '',
objetivoGeneral: [{ id: 1, text: "" }],
objEspec: Array
})
}
guardarInforme() {
this.service.addInforme(this.formInforme.value)
.subscribe(
rt => console.log(rt),
er => console.log(er),
() => console.log('Terminado')
);
}
addObjetivo(): void {
this.objGeneralIndex++;
this.objGeneral.push({ id: this.objGeneralIndex, text: "" });
}
delObjGral(obj): void {
for (var i = 0; i < this.objGeneral.length; i++) {
if (this.objGeneral[i].id == obj.id) {
this.objGeneral.splice(i, 1);
}
}
}
addObjectivoEspecifico(): void {
this.objEspecificosIndex++;
this.objEspecificos.push({ id: this.objEspecificosIndex, text: "" });
}
delObjEspecifico(obj): void {
for (var i = 0; i < this.objEspecificos.length; i++) {
if (this.objEspecificos[i].id == obj.id) {
this.objEspecificos.splice(i, 1);
}
}
}
}
/* DivTable.com */
.divTable{
display: table;
width: 100%;
}
.divTableRow {
display: table-row;
}
.divTableHeading {
background-color: #EEE;
display: table-header-group;
}
.divTableCell, .divTableHead {
text-align: center;
border: 1px solid #999999;
display: table-cell;
padding: 3px 10px;
}
.divTableHeading {
background-color: #EEE;
display: table-header-group;
font-weight: bold;
}
.divTableFoot {
background-color: #EEE;
display: table-footer-group;
font-weight: bold;
}
.divTableBody {
display: table-row-group;
}
button#addObjetivo, #addObjetivoEspec{
float: right;
margin-top:-60px;
}
button#btn_sent {
float: right;
margin-top: -81px;
margin-right: 12%;
}
#control-buttons{
float: right;
margin-top:-50px;
}
#dellCell{
width:5%;
}
#bodyInforme {
width: 90%;
margin-left: auto;
margin-right: auto;
}
#panelInforme {
height: 480px;
}
#overflowGral, #overflowEspec{
height: 300px;
overflow: auto;
}
<div class="container">
<div id="panelInforme" class="panel panel-default">
<div id="bodyInforme" class="panel-body">
<h3>Formulario Creación - Informe de Gestion</h3>
<div id="control-buttons">
<button (click)="showInfoBasic()" id="btn_general" type="button" class="btn btn-info">1</button>
<button (click)="showObjGral()" id="btn_especifico" type="button" class="btn btn-info">2</button>
<button (click)="showObjEspec()" id="btn_especifico" type="button" class="btn btn-info">3</button>
</div><hr>
<form novalidate [formGroup]="formInforme">
<button id="btn_sent" (click)="guardarInforme()" type="submit" class="btn btn-success">Enviar Informe</button>
<div id="infoBasic">
<h4>Información Básica</h4>
<hr>
<div class="form-group">
<label for="tituloInforme">Titulo de Informe</label>
<input id="tituloInforme" formControlName="tituloInforme" type="text" class="form-control" placeholder="Titulo de Informe">
</div>
<div class="form-group">
<label for="fechaInforme">Fecha:</label>
<input id="fechaInforme" formControlName="fechaInforme" type="text" class="form-control">
</div>
</div>
<div id="objGeneral">
<div id="objGral" class="form-group">
<h4>Ingrese Objetivos Generales</h4>
<hr>
<button (click)="addObjetivo()" id="addObjetivo" type="button" class="btn btn-success">Agregar Fila</button>
<div id="overflowGral">
<div class="divTable">
<div class="divTableBody">
<div class="divTableRow">
<div class="divTableCell">#</div>
<div class="divTableCell">Puntos</div>
</div>
<div *ngFor="let obj of objGeneral; let i = index;" id="tbl_objGeneral" class="divTableRow">
<div class="divTableCell">{{ (i+1) }}</div>
<div class="divTableCell">
<input id="objetivoGeneral" formControlName="objetivoGeneral" class="form-control" value="{{ obj.text }}" type="text" placeholder="Objetivo General">
</div>
<div class="divTableCell" id="dellCell">
<button (click)="delObjGral(obj)" type="button" class="btn btn-danger">Eliminar</button>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<div id="objEspec" class="form-group">
<h4>Ingrese Objetivos Específicos</h4>
<hr>
<button (click)="addObjectivoEspecifico()" id="addObjetivoEspec" type="button" class="btn btn-success">Agregar Fila</button>
<div id="tbl_espec" class="divTable">
<div id="overflowGral">
<div class="divTableBody">
<div class="divTableRow">
<div class="divTableCell">#</div>
<div class="divTableCell">Puntos</div>
</div>
<div *ngFor="let obj of objEspecificos; let i = index;" id="tbl_objGeneral" class="divTableRow">
<div class="divTableCell">{{ (i+1) }}</div>
<div class="divTableCell">
<input id="objEspec" formControlName="objEspec" class="form-control" value="{{ obj.text }}" type="text" placeholder="Ingrese Objetivos Específicos">
</div>
<div class="divTableCell" id="dellCell">
<button (click)="delObjEspecifico(obj)" type="button" class="btn btn-danger">Eliminar</button>
</div>
</div>
</div>
</div>
</div>
</div>
</form>
</div>
</div>
</div>
1 ответ
Я подозреваю, что вы должны использовать FormArray
класс для вашего objetivoGeneral
а также objEspec
поля:
this.formInforme = this.fb.group({
tituloInforme: '',
fechaInforme: '',
objetivoGeneral: this.fb.array([this.initObjetivo()]),
objEspec: this.fb.array([this.initObjEspec()])
})
initObjetivo() {
return this.fb.group({ id: this.objGeneralIndex++, text: "" });
}
addObjetivo(): void {
const objetivoArray = <FormArray>this.formInforme.controls['objetivoGeneral'];
const newObjetivo = this.initObjetivo();
objetivoArray.push(newObjetivo);
}
delObjGral(idx: number): void {
const objetivoArray = <FormArray>this.formInforme.controls['objetivoGeneral'];
objetivoArray.removeAt(idx);
}
initObjEspec() {
return this.fb.group({ id: this.objEspecificosIndex++, text: "" });
}
addObjectivoEspecifico(): void {
const objEspecArray = <FormArray>this.formInforme.controls['objEspec'];
const newobjEspec = this.initObjEspec();
objEspecArray.push(newobjEspec);
}
delObjEspecifico(idx: number): void {
const objEspecArray = <FormArray>this.formInforme.controls['objEspec'];
objEspecArray.removeAt(idx);
}
Вот пример представления для objetivoGeneral
наценка
<div id="overflowGral" formArrayName="objetivoGeneral">
<div class="divTable">
<div class="divTableBody">
<div class="divTableRow">
<div class="divTableCell">#</div>
<div class="divTableCell">Puntos</div>
</div>
<div [formGroupName]="i" *ngFor="let obj of formInforme.controls.objetivoGeneral.controls; let i=index" id="tbl_objGeneral" class="divTableRow">
<div class="divTableCell">{{ (i+1) }}</div>
<div class="divTableCell">
<input id="objetivoGeneral" formControlName="text" class="form-control" type="text" placeholder="Objetivo General">
</div>
<div class="divTableCell" id="dellCell">
<button (click)="delObjGral(i)" type="button" class="btn btn-danger">Eliminar</button>
</div>
</div>
</div>
</div>
</div>
PS The id
должен быть уникальным в документе. использование class
вместо id="tbl_objGeneral"