提交表单时如何触发表单验证(仅)?

时间:2020-11-05 13:39:53

标签: angular angular-forms angular2-form-validation

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

![enter image description here

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

enter image description here

仅当用户在出现错误时尝试提交表单时,我才想触发它。当然,如果出现错误(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>

1 个答案:

答案 0 :(得分:2)

  1. 未设置验证器。放空吧。
  2. 提交(只是按钮)时,如果需要,您可以通过setValidators()setErrors()添加验证器运行时。
  3. 出现错误后,您必须将具有空数组的验证器清除到setValidators()

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

我建议阅读更多API选项。

相关问题