0

我做了一个日期验证器。它验证现有日期。我需要具有其他限制的多个日期验证器,例如:不允许用户输入未来日期的最大日期验证器或只接受过去日期的日期验证器。这是我当前的验证器。

    export function dateValidator(group) {

  const {day, month, year} = group.value;
  const fullDate = `${day}/${month}/${year}`;
  const dobPattern = /^(\d{1,2})[-\/](\d{1,2})[-\/](\d{4})$/;
  const isStringValid = dobPattern.test(fullDate);

  let isValid = false;

  if (isStringValid) {
    const intDay = Number(day);
    const intMonth = Number(month);
    const intYear = Number(year);
    const jsMonth = intMonth - 1;
    const date = new Date(intYear, jsMonth, intDay);
    isValid = (date.getFullYear() === intYear && date.getMonth() === jsMonth && date.getDate() === intDay ;
  }

  return isValid ? null : { invalid: 'Invalid date' };
};

如何限制用户输入未来的日期。我将此代码与以下行一起使用:

    isValid = (date.getFullYear() === intYear && date.getMonth() === jsMonth && date.getDate() === intDay ;

但我想知道是否有一种更简单的方法,而不必一遍又一遍地复制和过去这段代码来对其进行小限制。

4

1 回答 1

1

您的dateValidator()函数应该是函数工厂(即返回函数的函数)而不是直接返回错误的函数:

export function dateValidator(maxDate: string): ValidatorFn {
  // Return a validator function.
  return (group: FormGroup): {[key: string]: any} => {
    // Re-use your existing validation code here and return the error if any.
    // Optionally, use the `maxDate` param to customize the validation:
    // entered dates should not go beyond `maxDate`.
  };
}

如您所见,您可以通过将参数传递给函数工厂来自定义验证器函数。在我的示例中,我使用了一个maxDate参数来指示验证器应该允许的最远日期。

在您的表单模型中,通过调用具有适当值的工厂来使用此验证器,例如:

this.myForm = fb.group({
  'date': ['', [Validators.required(), dateValidator('02/20/2017')]]
});

您可以在文档中看到另一个验证器的函数工厂示例:https ://angular.io/docs/ts/latest/cookbook/form-validation.html#custom-validation

于 2017-02-20T18:12:31.193 回答