反应形式的条件自定义验证不起作用 - Angular 9

时间:2021-01-09 15:20:11

标签: html angular typescript

我一定遗漏了什么:

<input
                  formControlName="endDate"
                  type="date"
                  id="endDate"
                  class="form-control"
                  (change)="onDateChange()"
                  required
                />
                <div *ngIf = "timesheetForm.get('endDate').errors?.invalidEndDate">
                <small class="text-danger"> TTTT</small></div>

和 .ts

  this.timesheetForm = this.fb.group({
      endDate: ["", DateValidators.invalidEndDate],
   }, {
     validator: DateValidators.invalidEndDate
   });

    const endDateControl = this.timesheetForm.get('endDate');

    endDateControl.valueChanges.subscribe((value) => {
        if (value) {
        this.timesheetForm.get('endDate').setValidators([DateValidators.invalidEndDate]);
      } else {
        this.timesheetForm.get('endDate').clearValidators();
      }
    });

这是我的自定义验证器

export class DateValidators {

    static invalidEndDate(formGroup: FormGroup): ValidationErrors | null  {
        let startDateTimestamp: number;
        let endDateTimestamp: number;
        for (const controlName in formGroup.controls) {
            if (controlName.indexOf("startDate") !== -1) {
                startDateTimestamp = Date.parse(formGroup.controls[controlName].value);
            }
            if (controlName.indexOf("endDate") !== -1) {
                endDateTimestamp = Date.parse(formGroup.controls[controlName].value);
            }
        }
        return (endDateTimestamp < startDateTimestamp) ? { invalidEndDate : true} : null;
    }

它返回 invalidEndDate:true,因此验证按预期工作,但我无法正确显示错误消息。

1 个答案:

答案 0 :(得分:2)

ValidatorFn 接口

接收控件并同步返回验证错误映射(如果存在)的函数,否则返回 null。

基于 angular.io docs

interface ValidatorFn {
  (control: AbstractControl): ValidationErrors | null
}

您必须在验证器构造函数中使用 control 而不是 formGroup。