Мы можем добиться этого, передавая элементы управления FormSray" FormArray ".
, для этого используйте следующий код в таблице ""-basic-example.ts".
createForm() {
this.externalPartiesForm = this.fb.group({
externalParties: this.fb.array([])
})
}
bindForm() {
let control = <FormArray>this.externalPartiesForm.get("externalParties");
this.dataSource.forEach(x => {
console.log('bind form');
control.push(this.fb.group({
id: x.id,
company: x.companyName,
contacts: this.fb.array(x.contact.map(i => this.fb.group({
id: i.id,
contactName: i.contactName,
emailId: i.emailId,
adminAgent: i.adminAgent,
collateralAgent: i.collateralAgent,
trusteeAgent: i.trusteeAgent,
})))
}))
});
}
в привязке dataSource , укажите элементы управления, а не значения, как показано ниже.
<mat-table #table [dataSource]='c.get("contacts").controls' formArrayName="contacts" ></mat-table>
Подробнокод " table-basic-example.html " ниже.
<code><form [formGroup]="externalPartiesForm">
<div formArrayName="externalParties">
<div *ngFor="let c of externalPartiesForm.get('externalParties').controls; let i = index;">
<div [formGroupName]="i">
<mat-divider></mat-divider>
<br />
<br />
<i>Company Name </i> {{c.value.company}}
<br />
<br />
<pre style="color:red;">{{c.get("contacts").value | json}}
Контактная информация Контактное лицо{{}} Element.value.contactNameEmail ID{{}} Element.value.emailIdАгент администрированияАгент обеспеченияПопечитель Агент
Для справки добавлен встроенный снимок экрана.
И код в ссылке ниже: https://stackblitz.com/edit/angular-riepzk-my4nvn?file=app/table-basic-example.html