admin管理员组文章数量:1323730
I'm getting an error: formArrayName must be used with a parent formGroup directive. You'll want to add a formGroup directive and pass it an existing FormGroup instance
. I'm not sure what am I doing wrong.
I would like the FormGroup to iterate several time(using ngFor
), and thought using formArrayName
would be the answer.
HTML:
<div formArrayName = "PaymentArray" *ngFor = "let meshalem of paymentForm.get('PaymentArray').controls;let i =index;">
<div [formGroup]="i">
<div class="row box-border" >
<div class="form-group col-xs-12 col-sm-12 col-md-5 pull-right required">
<label class="control-label">מספר ת.ז. משלם</label>
<input #PidField name="id_pay" id="id_pay" formControlName="id_pay" class="form-control input-lg"
maxlength="9" (input)="searchChange($event.target.value)" />
</div>
</div>
</div>
</div>
I'm getting an error: formArrayName must be used with a parent formGroup directive. You'll want to add a formGroup directive and pass it an existing FormGroup instance
. I'm not sure what am I doing wrong.
I would like the FormGroup to iterate several time(using ngFor
), and thought using formArrayName
would be the answer.
HTML:
<div formArrayName = "PaymentArray" *ngFor = "let meshalem of paymentForm.get('PaymentArray').controls;let i =index;">
<div [formGroup]="i">
<div class="row box-border" >
<div class="form-group col-xs-12 col-sm-12 col-md-5 pull-right required">
<label class="control-label">מספר ת.ז. משלם</label>
<input #PidField name="id_pay" id="id_pay" formControlName="id_pay" class="form-control input-lg"
maxlength="9" (input)="searchChange($event.target.value)" />
</div>
</div>
</div>
</div>
.ts File:
paymentForm = this.fb.group({
PaymentArray: this.fb.array([])
})
getPaymentList()
{
this._adminService.getPayment(this.id).subscribe(res => {
if(res.isSuccess)
{
this.PaymentList = res.data ;
this.PaymentList.forEach((pays) => {
this.meshalemArray = this.paymentForm.get('PaymentArray') as FormArray;
this.meshalemArray.push(this.fb.group({
id_pay:[pays.id_pay,Validators.pose([Validators.pattern("^[0-9]*$"), Validators.required])],
numberRooms:[pays.numberRooms],
sum: [pays.sum],
paymentMethod:[pays.paymentMethod],
credit:[pays.credit],
}))
})
}
else
{
//TODO
}
})
}
Share
Improve this question
asked May 10, 2019 at 7:07
JumpIntoTheWaterJumpIntoTheWater
1,3363 gold badges23 silver badges55 bronze badges
1 Answer
Reset to default 9Error is causing because you are not using FormArray
inside FormGroup
. Just wrap the FormArray
inside the FormGroup
:-
<form [formGroup]="paymentForm">
<div formArrayName = "PaymentArray" *ngFor = "let meshalem of paymentForm.get('PaymentArray').controls;let i =index;">
<div [formGroup]="i">
<div class="row box-border" >
<div class="form-group col-xs-12 col-sm-12 col-md-5 pull-right required">
<label class="control-label">מספר ת.ז. משלם</label>
<input #PidField name="id_pay" id="id_pay" formControlName="id_pay" class="form-control input-lg"
maxlength="9" (input)="searchChange($event.target.value)" />
</div>
</div>
</div>
</div>
</form>
And I think <div [formGroup]="i">
should be eigther <div [formGroupName]="i">
or <div [formGroup]="meshalem">
本文标签: javascriptformArrayName must be used with a parent formGroup directiveStack Overflow
版权声明:本文标题:javascript - formArrayName must be used with a parent formGroup directive - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1742122076a2421760.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论