在Angular 8.3.15中,如果您尝试创建带有参数的自定义验证器,则可能会遇到一些问题。 以下是如何解决此问题的示例代码:
首先,创建一个带有参数的自定义验证器,该验证器将确保输入的值不小于传入的参数值。 在这个例子中,我们将使用“minValue”作为参数名称。
import { AbstractControl, ValidationErrors, ValidatorFn } from '@angular/forms';
export function minValueValidator(minValue: number): ValidatorFn {
return (control: AbstractControl): ValidationErrors | null => {
const value = control.value;
if (value === null || value === undefined || isNaN(value)) {
return { 'minValue': true };
}
return value >= minValue ? null : { 'minValue': true };
};
}
在模板中,将验证器应用于表单控件:
Value must be greater than or equal to 5.
注意:为了使用我们自己创建的验证器,需要将其添加到 AppModule 中的 providers 数组中:
import { minValueValidator } from './validators/min-value-validator';
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule,
FormsModule,
ReactiveFormsModule
],
providers: [
{ provide: 'minValue', useValue: minValueValidator }
],
bootstrap: [AppComponent]
})
export class AppModule { }