简体   繁体   English

formArrayName必须与父formGroup指令一起使用

[英]formArrayName must be used with a parent formGroup directive

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 我收到一个错误: 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 . 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. 我希望FormGroup迭代几次(使用ngFor ),并认为使用formArrayName将是答案。

HTML: 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: .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 } }) } 

Error is causing because you are not using FormArray inside FormGroup . 错误是因为您没有使用造成FormArrayFormGroup Just wrap the FormArray inside the FormGroup :- 只需将FormArray包装在FormArrayFormGroup :-

<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"> 而且我认为<div [formGroup]="i">应该是<div [formGroupName]="i"><div [formGroup]="meshalem">

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM