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事件后异步验证器获取的是最新的值。

相关内容

热门资讯

三分钟了解!wepoker俱乐... 三分钟了解!wepoker俱乐部辅助,广西老友玩有破解视频,教你教程(有人有挂)-哔哩哔哩亲,关键说...
关于!wpk透视挂,德普软件,... 关于!wpk透视挂,德普软件,透视教程(有人有挂)-哔哩哔哩1、首先打开德普软件最新版本,在德普软件...
一分钟了解!wepoker轻量... 一分钟了解!wepoker轻量版透视方法,手游字牌辅助脚本工具,新2025教程(有挂讲解)-哔哩哔哩...
热门推荐!拱趴大菠萝可以开挂,... 热门推荐!拱趴大菠萝可以开挂,九九联盟解码器,规律教程(有挂详细)-哔哩哔哩拱趴大菠萝可以开挂辅助器...
玩家必备教程!wepoker可... 玩家必备教程!wepoker可以看底牌,丫丫衡阳字牌2辅助,2025新版教程(讲解有挂)-哔哩哔哩1...
我来教大家!hhpoker德州... 我来教大家!hhpoker德州透视挂,花舍辅助,揭秘攻略(有挂神器)-哔哩哔哩hhpoker德州透视...
分享开挂内幕!pokemmo辅... 分享开挂内幕!pokemmo辅助工具,广西老友玩老师输可以版,透牌教程(有挂透视)-哔哩哔哩1、很好...
攻略讲解!we poker插件... 攻略讲解!we poker插件,wejoker手机版透视脚本,2025新版技巧(有挂方略)-哔哩哔哩...
让我来分享经验!德州之星扫描器... 让我来分享经验!德州之星扫描器,阿拉游戏中心辅助挂教程,曝光教程(有挂辅助)-哔哩哔哩1、阿拉游戏中...
总算了解!德普辅助软件,微乐贵... 总算了解!德普辅助软件,微乐贵阳捉鸡麻将能不能开挂,德州教程(有挂方针)-哔哩哔哩微乐贵阳捉鸡麻将能...