Angular的FormControl在blur事件后异步验证器仍然获取旧值。
创始人
2024-10-24 03:31:31
0

在Angular中,当FormControl的blur事件触发时,异步验证器获取的确实是旧值。这是因为blur事件触发时,FormControl的值尚未更新。

要解决这个问题,可以使用valueChanges观察FormControl的值的变化,并在值变化时进行异步验证。

下面是一个示例代码:

import { Component } from '@angular/core';
import { FormControl, Validators } from '@angular/forms';

@Component({
  selector: 'app-example',
  template: `
    
    
Async validation failed
`, }) export class ExampleComponent { myControl = new FormControl('', null, this.asyncValidator); asyncValidator(control: FormControl) { return new Promise(resolve => { setTimeout(() => { if (control.value === 'old value') { resolve({ asyncValidator: true }); } else { resolve(null); } }, 2000); // 模拟异步验证 }); } validateAsync() { this.myControl.updateValueAndValidity(); // 更新值和验证状态 // 可以在这里订阅FormControl的valueChanges,获取最新的值进行异步验证 this.myControl.valueChanges.subscribe(value => { this.myControl.updateValueAndValidity(); // 更新值和验证状态 }); } }

在上面的示例代码中,我们在FormControl的blur事件中调用validateAsync方法进行异步验证。在validateAsync方法中,我们先调用updateValueAndValidity方法来更新FormControl的值和验证状态。然后,在valueChanges的订阅回调函数中,我们再次调用updateValueAndValidity方法来获取最新的值并进行验证。

这样,就可以确保在blur事件后异步验证器获取的是最新的值。

相关内容

热门资讯

透视能赢!wpk软件是真的吗,... 透视能赢!wpk软件是真的吗,wpk私人辅助,2025新版教程(本来有挂);1、上手简单,内置详细流...
透视ai!we poker插件... 透视ai!we poker插件,素来存在有挂(透视)可靠技巧(有挂介绍)1、每一步都需要思考,不同水...
透视教学!pokemmo手机版... 透视教学!pokemmo手机版脚本免费,werplan外卦神器,透明挂教程(有挂脚本)1、pokem...
透视挂!wpk官网下载链接,原... 透视挂!wpk官网下载链接,原先有挂(透视)力荐教程(有挂解说);1、让任何用户在无需wpk官网下载...
透视挂透视!wpk私人辅助,微... 透视挂透视!wpk私人辅助,微扑克微乐辅助,攻略方法(真是存在有挂);1、微扑克微乐辅助系统规律教程...
透视存在!拱趴大菠萝挂哪里,哈... 透视存在!拱趴大菠萝挂哪里,哈糖大菠萝破解器,技巧教程(有挂介绍);1)拱趴大菠萝挂哪里辅助挂:进一...
透视透视挂!wepoker手机... 透视透视挂!wepoker手机版辅助,起初真的有挂(透视)2025教程(有挂技巧)1、用户打开应用后...
透视辅助!wpk德州局怎么透视... 透视辅助!wpk德州局怎么透视,wpk辅助插件,靠谱教程(一直真的有挂)1、很好的工具软件,可以解锁...
透视总结!福建大菠萝万能辅助器... 透视总结!福建大菠萝万能辅助器,佛手在线有挂吗,力荐教程(有挂辅助)1、上手简单,内置详细流程视频教...
透视智能ai!如何下载德普之星... 透视智能ai!如何下载德普之星辅助软件,从来存在有挂(透视)新版2025教程(有挂介绍)在进入如何下...