@zlodiak

Почему не валидируется вложенная форма?

Я пытаюсь создать вложенную форму на основе formGroups. Вот моя модель формы:
this.formGroup = this.formBuilder.group({
      'vehType': [null, Validators.required],
      'gosNum': [null, Validators.required],
      'body': this.formGroup = this.formBuilder.group({
        'bodyCapacity': [null, [Validators.required]],
        'bodyVolume': [null, [Validators.required]],
      }),
      'trailer': this.formGroup = this.formBuilder.group({
        'trailerCapacity': [null, [Validators.required]],
        'trailerVolume': [null, [Validators.required]],
      }),
    });


Вот соответствующий шаблон:
<form [formGroup]="formGroup" (ngSubmit)="onSubmit(formGroup.value)" class="form">

    <mat-card>
      <mat-form-field>
        <mat-select  formControlName="vehType">
          <mat-option *ngFor="let option of vehTypes" [value]="option">
            {{ option }}
          </mat-option>
        </mat-select>
      </mat-form-field>
      <mat-form-field>
        <input matInput placeholder="gosNum" formControlName="gosNum">
      </mat-form-field>      
    </mat-card>

    <mat-card [formGroupName]="body">
      <mat-form-field>
        <input matInput placeholder="bodyCapacity" formControlName="bodyCapacity">
      </mat-form-field>  
      <mat-form-field>
        <input matInput placeholder="bodyVolume" formControlName="bodyVolume">
      </mat-form-field>        
    </mat-card>

    <mat-card [formGroupName]="trailer">
      <mat-form-field>
        <input matInput placeholder="trailerCapacity" formControlName="trailerCapacity">
      </mat-form-field>  
      <mat-form-field>
        <input matInput placeholder="trailerVolume" formControlName="trailerVolume">
      </mat-form-field>        
    </mat-card>    

    <div>
      <button mat-raised-button type="submit" [disabled]="!formGroup.valid">Submit Form</button>
    </div>

  </form>


Проблема в том, что даже при всех заполненных полях, вложенные части формы невалидны и форма полностью является невалидной. Это можно увидеть через кнопку отладки, которую я поместил внизу страницы в LIVE DEMO

Помогите пожалуйста исправить валидацию таким образом, что:
1. при заполненных всех полях родительская форма является валидной.
2. при заполненных полях вложенной формы, вложенная форма является валидной, а родительская форма - не обязательно.
  • Вопрос задан
  • 167 просмотров
Решения вопроса 1
Xuxicheta
@Xuxicheta Куратор тега Angular
инженер
<mat-card [formGroupName]="body">
у компонента нет поля body
ошибки типа
Cannot find control with unspecified name attribute
в консоли не смутили чтоли?

Квадратные скобки убери и все заработает. Вот так
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
23 нояб. 2024, в 00:16
2000 руб./за проект
22 нояб. 2024, в 23:55
3000 руб./за проект
22 нояб. 2024, в 22:26
3500 руб./за проект