【发布时间】:2019-03-10 18:15:05
【问题描述】:
晚上好,
我已经建立了一个反应形式的结构。有一个鸡尾酒阵列,其中包括一个成分阵列。
这应该以我称为existingFlavForms 的反应形式进行投影。
问题是,我无法访问嵌套成分 formArray。
this.existingFlavForm = this.fb.group({
flavs: this.fb.array([])
});
for (let i = 0; i < this.cocktails.length; i++) {
this.existingFlavForms.push(this.fb.group({
id: [this.cocktails[i].id],
c_name: [this.cocktails[i].c_name],
mark: [this.cocktails[i].mark],
imgUrl: [this.cocktails[i].imgUrl],
ingrs: this.fb.array([
{ingr: [this.cocktails[i].ingr]}
]
)
}));
}
这是模板脚本,我尝试访问所有内容。
<form [formGroup]="existingFlavForm">
<div formArrayName="flavs">
<div *ngFor="let flav of existingFlavForms.controls; let i=index">
<mat-expansion-panel class="myPanel">
<mat-expansion-panel-header>
<mat-panel-title>
<h3 class="text-info"> {{flav.value.c_name}} </h3>
</mat-panel-title>
<mat-icon class="mr-lg-3 mt-lg-2">settings</mat-icon>
<mat-icon class="mr-lg-3 mt-lg-2" (click)="deleteCocktail()">delete</mat-icon>
</mat-expansion-panel-header>
<div class="row">
<div [formGroupName]="i">
<div formArrayName="ingrs">
<p *ngFor="let ingr of flav[i].controls.ingrs.controls;">
{{ingr.i_name}}
</p>
</div>
</div>
</div>
</mat-expansion-panel>
</div>
</div>
</form>
我搜索了类似的问题,但找不到合适的解决方案。数据在那里并且完全初始化。
这表示浏览器控制台..
"TypeError: undefined is not an object (evaluating '_v.context.$implicit[_v.context.index].controls')"
最好的问候!
我现在添加了一个基本的 stackblitz,它显示了带有虚拟数据的一般数据结构。 https://stackblitz.com/edit/angular-l3ghac
【问题讨论】:
-
控制台的哪一行显示错误信息?
-
在您的 for 循环中,您将推送到现有的 FlavForms,但这是一个 formGroup 而不是 formArray,因此它没有推送方法。
-
TypeError: undefined is not an object (evalating _v.context.$implicit[_v.context.index].controls') 在行但如果我删除在
元素之后,我没有收到任何错误。所以这是迭代发生的那一行..
标签: angular angular-reactive-forms formarray