在Angular 8中,如果异步自定义验证器不起作用并显示错误消息,可以尝试以下解决方法:
import { AsyncValidatorFn, AbstractControl, ValidationErrors } from '@angular/forms';
import { AsyncValidatorFn, AbstractControl, ValidationErrors } from '@angular/forms';
import { Observable } from 'rxjs';
import { map } from 'rxjs/operators';
export function uniqueNameValidator(): AsyncValidatorFn {
return (control: AbstractControl): Promise | Observable => {
// 异步验证逻辑
// 返回一个Promise或Observable以指示验证是否通过
};
}
import { Component } from '@angular/core';
import { FormControl, FormGroup, Validators } from '@angular/forms';
import { uniqueNameValidator } from './validators';
@Component({
selector: 'app-root',
template: `
`
})
export class AppComponent {
myForm: FormGroup;
constructor() {
this.myForm = new FormGroup({
name: new FormControl('', [Validators.required], [uniqueNameValidator()])
});
}
}
确保在FormControl的第三个参数中传递了异步验证器函数,并将其添加到FormControl的验证器数组中。
myForm.get('name').errors?.uniqueName
来检查是否有uniqueName错误,并显示相应的错误消息。通过执行以上步骤,您应该能够在Angular 8中正确使用异步自定义验证器并显示错误消息。