如何解决Angular 9异步验证
我试图在Angular 9中编写一个AsyncValidatorFn,但遇到了一个问题。
如果我尝试在触发前引入去抖动功能以轮询状态更改,则该函数似乎未将错误消息返回到我的响应形式。如果没有去抖动,它将完美触发,但不会轮询在实时环境中对服务器不必要的流量。谁能看看我的代码并发现问题?
我看过各种示例,它们似乎都以这种方式运行并声称可以工作。
export function CodeExistsValidator(service: Service): AsyncValidatorFn {
return (control: AbstractControl): Observable<ValidationErrors | null> => {
return timer(500).pipe(switchMap(() => {
return service.checkExists(control.value)
.pipe(map((response: any) => {
return response.data ? { codeExists: true } : null;
}));
}));
}
}
解决方法
事实证明,上面的方法非常有效,问题出在服务器端。不敢相信我错过了。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。