日期最小值的 Angular 自定义验证器
Angular5 Custom Validator for Date Min
我正在尝试为日期输入创建一个验证器。
所以我写了这段代码,但它没有按预期工作!
export class CustomValidators {
static dateMinimum(date: string): ValidatorFn {
return (control: AbstractControl): ValidationErrors | null => {
if (control.value == null) {
return null;
}
const controlDate = moment(control.value, FORMAT_DATE);
if (!controlDate.isValid()) {
return null;
}
const validationDate = moment(date);
return controlDate.isAfter(validationDate) ? null : {
'date-minimum': {
'date-minimum': validationDate.format(FORMAT_DATE),
'actual': controlDate.format(FORMAT_DATE)
}
};
};
}
}
我遇到了这个错误
ERROR Error: Expected validator to return Promise or Observable.at toObservable (forms.js:749)
我真的不知道哪件事是不正确的...我找到了很多关于如何创建不带参数的自定义验证器的示例,但是 none 带参数...
我需要像这样使用验证器:
this.projectForm = this.builder.group({
date: ['', Validators.required, CustomValidators.dateMinimum('2018-12-12')],
});
一切正常....
问题出在表单创建本身...
date: ['', Validators.required, CustomValidators.dateMinimum('2018-12-12')],
应该是
date: ['', [Validators.required, CustomValidators.dateMinimum('2018-12-12')]],
我正在尝试为日期输入创建一个验证器。
所以我写了这段代码,但它没有按预期工作!
export class CustomValidators {
static dateMinimum(date: string): ValidatorFn {
return (control: AbstractControl): ValidationErrors | null => {
if (control.value == null) {
return null;
}
const controlDate = moment(control.value, FORMAT_DATE);
if (!controlDate.isValid()) {
return null;
}
const validationDate = moment(date);
return controlDate.isAfter(validationDate) ? null : {
'date-minimum': {
'date-minimum': validationDate.format(FORMAT_DATE),
'actual': controlDate.format(FORMAT_DATE)
}
};
};
}
}
我遇到了这个错误
ERROR Error: Expected validator to return Promise or Observable.at toObservable (forms.js:749)
我真的不知道哪件事是不正确的...我找到了很多关于如何创建不带参数的自定义验证器的示例,但是 none 带参数...
我需要像这样使用验证器:
this.projectForm = this.builder.group({
date: ['', Validators.required, CustomValidators.dateMinimum('2018-12-12')],
});
一切正常....
问题出在表单创建本身...
date: ['', Validators.required, CustomValidators.dateMinimum('2018-12-12')],
应该是
date: ['', [Validators.required, CustomValidators.dateMinimum('2018-12-12')]],