formArrayName должно использоваться с родительской директивой formGroup - PullRequest
1 голос
/ 10 мая 2019

Я получаю сообщение об ошибке: 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
            }
        })
    
  }

1 Ответ

5 голосов
/ 10 мая 2019

Ошибка вызвана тем, что вы не используете FormArray внутри FormGroup.Просто оберните 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">

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...