从晚上开始,我在augular2中玩过表单验证.
所有基本案例都易于实现,并且工作正常,但我坚持使用异步验证.我创建了一个非常小的例子http://plnkr.co/edit/Xo8xwJjhlHkXrunzS8ZE,它没有用.
根据测试"应该在状态已经更新为挂起之后触发事件"来自model_spec.ts通过创建控制组进行注册假设以某种方式工作
builder.group({login: ["",Validators.required,validationFuctionWhichReturnsPromise]
Run Code Online (Sandbox Code Playgroud)
我花了整整一个晚上才发现这个代码已经在alfa-46中发布了(我使用了alfa-45),并且在更新依赖后,异步验证开始起作用.该功能非常新鲜,但没有完整记录
(对于尚未尝试过的人)基本上异步验证器是一个具有Control参数并返回验证结果的promise的函数.注册验证器有两种方法.1)我在我的例子中使用的那个和2)作为通过NG_ASYNC_VALIDATORS提供验证器的指令(参见UniqLoginValidator和NgFormControl以了解它是如何工作的).您可以编写多个验证器(尚未测试,但执行此操作的函数在代码中,请参阅https://github.com/angular/angular/commit/cf449dd).
但是当我最终达到并运行验证器时,一个新的问题就到了.异步验证器非常适合在服务器端验证中使用它.但是在每个keyup之后每次更改model.fe之后都会调用验证.因此,如果我们将在每个密钥启动后向服务器发送请求,那么它将不会太有效;)我检查了它是如何在角度1中完成的,并且它们可以去除验证事件.
我的问题是:
我正在考虑使用debounce(来自underscorejs)来扭曲验证器函数,但它不会起作用,因为angular希望每次都获得一个有效的promise.
我的第二个问题是,如果所有事件都使用RxJs,那么也许我可以在负责验证的事件流上应用debounce.在model.ts中,从验证器返回的promise是更改为observable并添加了新订阅.我们没有任何障碍物(Observable)可以在那里申请去抖.
我在如何触发angular2中的表单验证器时发现了一个密切相关的问题
PS还有与异步验证器相关的其他问题,它仍然是打开的https://github.com/angular/angular/issues/1068