![](/img/trans.png)
[英]How to use formArrayName with a parent formGroup directive. Angular
[英]formArrayName must be used with a parent formGroup directive
我收到一個錯誤: formArrayName must be used with a parent formGroup directive. You'll want to add a formGroup directive and pass it an existing FormGroup instance
formArrayName must be used with a parent formGroup directive. You'll want to add a formGroup directive and pass it an existing FormGroup instance
。 我不確定我在做什么錯。 我希望FormGroup迭代幾次(使用ngFor
),並認為使用formArrayName
將是答案。
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文件:
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.compose([Validators.pattern("^[0-9]*$"), Validators.required])], numberRooms:[pays.numberRooms], sum: [pays.sum], paymentMethod:[pays.paymentMethod], credit:[pays.credit], })) }) } else { //TODO } }) }
錯誤是因為您沒有使用造成FormArray
內FormGroup
。 只需將FormArray
包裝在FormArray
中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>
而且我認為<div [formGroup]="i">
應該是<div [formGroupName]="i">
或<div [formGroup]="meshalem">
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.