1

我创建了一个动态表单,您可以在其中使用专用按钮添加或删除字段:

![在此处输入图像描述

问题是当我们添加一个新字段时,会立即触发表单验证,从而导致显示错误消息:

在此处输入图像描述

我只想在用户在出现错误时尝试提交表单时触发它。当然如果有错误也不能提交表单(Validators.required,nicknameValidator())

以下是在表单中生成新行的代码:

createNicknameFormGroup(): any {
  return new FormGroup({
    nickname: new FormControl('', Validators.required, this.isValidNicknameService.nicknameValidator())
  }, { updateOn: 'blur' })
}

以及负责显示这些行的 html 代码:

<div *ngFor="let nickname of nicknamesFormArray.controls; let i = index;" class="row">

  <div [formGroupName]="i">

    <mat-form-field appearance="outline" class="nickname-form-field">
      <mat-label>{{formFieldsInfo.nicknames.label}}</mat-label>
      <input matInput [placeholder]=formFieldsInfo.nicknames.placeholder formControlName="nickname"
             type="text"
             class="form-control">
      <mat-hint>{{formFieldsInfo.nicknames.hint}}</mat-hint>
      <mat-error *ngIf="nicknamesFormArray.controls[i].get('nickname').errors?.required">
        {{formFieldsInfo.nicknames.errorMessages.required}}
      </mat-error>
      <mat-error *ngIf="nicknamesFormArray.controls[i].get('nickname').errors?.shouldNotStartWithA">
        {{formFieldsInfo.nicknames.errorMessages.shouldNotStartWithA}}
      </mat-error>
    </mat-form-field>

    <mat-icon (click)="removeNicknameFromNicknamesFormArray(i)" class="clear">
      clear
    </mat-icon>

  </div>

</div>
4

1 回答 1

2
  1. 未设置验证器。就放空吧。
  2. 提交时(只是按钮),您可以根据需要添加验证器运行setValidators()setErrors()
  3. 存在/存在错误后,您必须将带有空数组的验证器清理到setValidators()

https://angular.io/api/forms/AbstractControl#setValidators https://angular.io/api/forms/AbstractControl#setErrors

我建议阅读更多 API 选项。

于 2020-11-05T13:51:51.777 回答