Angular 7 - включить форму отправки с полем FormControl

Моя FormGroup имеет 3 поля: 2 текстовых поля и 1 FormControl.

Все поля обязательны, и FormControl имеет один конкретный валидатор:

generateForm(scanfolder) {
console.log('generateForm');
this.origineControl.setValidators(this.forbiddenNamesValidator(this.options))
const fb: FormBuilder = new FormBuilder();
this.scanfolderForm = fb.group({
  'fullpath': [scanfolder.fullpath, [Validators.required]],
  'name': [scanfolder.name, [Validators.required]],
  'origin': [this.origineControl, [Validators.required]],
});
}

Особый контроль:

forbiddenNamesValidator(names: string[]): ValidatorFn {
return (control: AbstractControl): { [key: string]: any } | null => {
  console.log(typeof control );
  console.log(control.value );
  // below findIndex will check if control.value is equal to one of our options or not
  const index = names.findIndex(name => {
    return (new RegExp('\^' + name + '\$')).test(control.value);
  });
  return index < 0 ? { 'forbiddenNames': { value: control.value } } : null;
};
}

Когда поля заполнены, кнопка формы отправки должна быть включена, но она не работает:

перед введите описание изображения здесь

после:  введите описание изображения здесь

Мы видим, что кнопка доступна, тогда как у 2-го поля есть ошибка

Вот мой HTML:

          <form [formGroup]="scanfolderForm">
        <div class="row">
          <mat-form-field class="col-md-4">
            <input matInput placeholder="Chemin complet"  formControlName="fullpath" name="fullpath">
            <mat-error *ngIf="scanfolderForm.controls['fullpath'].errors?.incorrectName">Saisie incorrecte</mat-error>
          </mat-form-field>
          <mat-form-field class="col-md-4">
            <input type="text" placeholder="Pick one" aria-label="Number" matInput [formControl]="origineControl" [matAutocomplete]="auto" required>
            <mat-autocomplete #auto="matAutocomplete">
              <mat-option *ngFor="let option of options" [value]="option">
                {{option}}
              </mat-option>
            </mat-autocomplete>
            <mat-error *ngIf="origineControl.hasError('forbiddenNames')">
              You should enter value from suggested one only. <strong>'{{origineControl.errors.forbiddenNames.value}}'</strong> is not allowed.
            </mat-error>
            <mat-error *ngIf="origineControl.hasError('required')">
              This is <strong>required</strong>
            </mat-error>
          </mat-form-field>
          <mat-form-field class="col-md-4">
          <input matInput placeholder="Nom" formControlName="name" name="name">
          </mat-form-field>
        </div>
     </form>
    

<mat-dialog-actions *ngIf="!loading">
 <button class="btn btn-primary" *ngIf="action === 2 && !isDisabled" (click)="cuScanfolder()" 
  [disabled]="!scanfolderForm.valid">M.A.J</button>
  <button class="btn btn-warning" *ngIf="data.list.length < 2" (click)="nextOne()" cdkFocusInitial>Retour</button>
</mat-dialog-actions>

person anakin59490    schedule 28.10.2020    source источник


Ответы (1)


из официального

Когда вы добавляете или удаляете валидатор во время выполнения, вы должны вызвать updateValueAndValidity (), чтобы новая валидация вступила в силу.

this.origineControl.setValidators([this.forbiddenNamesValidator(this.options), Validators.required]);
const fb: FormBuilder = new FormBuilder();
this.scanfolderForm = fb.group({
  'fullpath': [scanfolder.fullpath, [Validators.required]],
  'name': [scanfolder.name, [Validators.required]]
});
this.scanfolderForm.addControl('origin', this.origineControl)
this.scanfolderForm.updateValueAndValidity();
<mat-form-field class="col-md-4">
  <input type="text" placeholder="Pick one" aria-label="Number" matInput formControlName="origin" [matAutocomplete]="auto" required>
  <mat-autocomplete #auto="matAutocomplete">
    <mat-option *ngFor="let option of options" [value]="option">
      {{option}}
    </mat-option>
  </mat-autocomplete>
  <mat-error *ngIf="scanfolderForm.get('origin').hasError('forbiddenNames')">
    You should enter value from suggested one only. <strong>'{{scanfolderForm.get('origin').errors.forbiddenNames.value}}'</strong> is not allowed.
  </mat-error>
  <mat-error *ngIf="scanfolderForm.get('origin').hasError('required')">
    This is <strong>required</strong>
  </mat-error>
</mat-form-field>
person ttquang1063750    schedule 28.10.2020
comment
Спасибо за ваш ответ. Но это все равно не работает - person anakin59490; 28.10.2020
comment
Вы могли бы привязать неправильный элемент управления вместо [formControl]="origineControl" вам нужно formControlName="origin", не так ли? - person ttquang1063750; 28.10.2020