Angular 异步验证器 FormControls 直到失焦时才更新。
创始人
2024-10-20 23:01:17
0

在Angular中,可以使用异步验证器来对表单控件进行验证。为了实现“直到失焦时才更新”的功能,可以使用updateOn选项来指定何时更新控件的值。

下面是一个示例代码,演示了如何使用异步验证器和updateOn选项来实现该功能:

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

@Component({
  selector: 'app-my-form',
  template: `
    
正在验证...
该字段为必填项。
自定义验证错误。
`, }) export class MyFormComponent { myForm: FormGroup; myControl: FormControl; isBlurred = false; constructor() { this.myControl = new FormControl('', { validators: [Validators.required], asyncValidators: [this.customValidator], updateOn: 'blur', // 在失焦时更新控件的值 }); this.myForm = new FormGroup({ myControl: this.myControl, }); } onBlur() { this.isBlurred = true; } customValidator(control: FormControl) { // 模拟一个异步验证器 return new Promise(resolve => { setTimeout(() => { if (control.value === 'example') { resolve({ custom: true }); // 验证失败 } else { resolve(null); // 验证通过 } }, 1000); }); } }

在这个示例中,我们定义了一个名为myControl的FormControl,并使用updateOn选项将其设置为blur,从而在失焦时才更新控件的值。

在模板中,我们使用blur事件监听器来调用onBlur方法,以便在失焦时设置isBlurred标志为true。然后,我们使用*ngIf指令分别显示正在验证的消息和验证错误消息。

在自定义验证器customValidator中,我们模拟了一个异步验证器,它在1秒后返回验证结果。如果输入值为example,则验证失败,否则验证通过。

请注意,上述代码是使用Angular的响应式表单实现的。如果您正在使用模板驱动表单,请使用ngModel指令的updateOn选项。

相关内容

热门资讯

七分钟辅助!丽水茶苑苹果手机辅... 七分钟辅助!丽水茶苑苹果手机辅助,本来是真的有辅助教程(有挂方式)1、实时丽水茶苑苹果手机辅助透视辅...
第一分钟辅助!闲来辅助神器下载... 第一分钟辅助!闲来辅助神器下载2022,好像真的有辅助方法(有挂教程)1、不需要AI权限,帮助你快速...
九分钟辅助!丽水都莱辅助工具试... 九分钟辅助!丽水都莱辅助工具试用,确实存在有辅助神器(有挂方法)九分钟辅助!丽水都莱辅助工具试用,确...
第一分钟辅助!蛮王辅助器,好像... 第一分钟辅助!蛮王辅助器,好像是有辅助方法(有挂教学)1、首先打开蛮王辅助器辅助器下载最新版本,在蛮...
第六分钟辅助!潮汕汇挂,一贯真... 第六分钟辅助!潮汕汇挂,一贯真的是有辅助插件(有挂辅助)1、这是跨平台的潮汕汇挂轻量版有透视,在线的...
六分钟辅助!微信开心泉州辅助器... 六分钟辅助!微信开心泉州辅助器,一直有辅助器(有挂教学)1、下载好微信开心泉州辅助器透视辅助下载之后...
第3分钟辅助!佛手十三道破解版... 第3分钟辅助!佛手十三道破解版安卓,竟然真的有辅助攻略(有挂存在)1、让任何用户在无需佛手十三道破解...
2分钟辅助!sohoo竞技联盟... 2分钟辅助!sohoo竞技联盟辅助,切实真的有辅助脚本(有挂技术)1.sohoo竞技联盟辅助 选牌创...
第8分钟辅助!心悦手游辅助器,... 第8分钟辅助!心悦手游辅助器,原来真的是有辅助技巧(确实有挂);1、每一步都需要思考,不同水平的挑战...
第十分钟辅助!广东雀神祈福真的... 第十分钟辅助!广东雀神祈福真的有用吗,都是是有辅助技巧(有挂方略)1、下载好广东雀神祈福真的有用吗透...