在AngularJS中,可以使用以下命令设置输入,以延迟验证
link(scope, elem, attr, ngModel) {
ngModel.$overrideModelOptions({
updateOn: 'default blur',
debounce: {
blur: 0,
default: 500,
},
});
}这样做是:当输入发生变化时,在输入验证有效/无效之前,会给出500毫秒的延迟。
在Angular2+中,这似乎更加困难。我认为我可以用可观察的方式来听这些更改,并以这种方式更新验证,但是我如何告诉初始输入不验证呢?
发布于 2018-04-05 20:28:40
由于角5.0有更多的控制什么时候运行您的表单验证。可以使用blur选项将验证配置为在submit或updateOn上运行。
将在窗体控件模糊上运行验证程序:
new FormControl(null, {
updateOn: 'blur'
});将在表单提交后运行验证程序:
new FormGroup({
fistName: new FormControl(),
lastName: new FormControl()
}, { updateOn: 'submit' });将在窗体控件模糊上运行验证程序:
<input [(ngModel)]="firstName" [ngModelOptions]="{updateOn: 'blur'}">将在表单提交后运行验证程序:
文档中的更多信息
正如注释中所提到的那样,您也可以订阅表单值更改流,但是如果您对延迟的表单验证感兴趣,您可能应该查看updateOn属性。
https://stackoverflow.com/questions/49680775
复制相似问题