Angular 6,this.formGroup.updateValueAndValidity()不正常工作。
创始人
2024-10-16 12:30:27
0

问题描述: 在Angular 6中,当调用this.formGroup.updateValueAndValidity()时,表单验证似乎不起作用,即使输入字段的值已更改也是如此。

解决方法: 以下是一些可能的解决方法和代码示例:

  1. 确保你的表单控件已正确绑定到表单组。在模板中,确保使用formControlName指令将控件绑定到表单组。示例如下:

在模板中:

在组件中:

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

// 创建表单组和控件
formGroup: FormGroup = new FormGroup({
  name: new FormControl('')
});
  1. 确保在更新表单值和有效性之前,已正确订阅了表单控件的值更改。示例如下:

在组件中:

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

// 创建表单组和控件
formGroup: FormGroup = new FormGroup({
  name: new FormControl('')
});

ngOnInit() {
  // 订阅表单控件值的更改
  this.formGroup.get('name').valueChanges.subscribe(() => {
    // 更新表单值和有效性
    this.formGroup.updateValueAndValidity();
  });
}
  1. 如果表单中使用了自定义验证器,请确保自定义验证器函数返回正确的验证结果。示例如下:

在组件中:

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

// 创建表单组和控件
formGroup: FormGroup = new FormGroup({
  name: new FormControl('', [Validators.required, this.customValidator])
});

customValidator(control: FormControl) {
  // 自定义验证逻辑
  if (control.value === 'abc') {
    return { invalidValue: true };
  }
  return null;
}

在模板中,你可以通过formGroup.controls['name'].errors获取自定义验证器返回的错误对象。

这些解决方法应该可以帮助你解决Angular 6中this.formGroup.updateValueAndValidity()不正常工作的问题。请根据你的实际情况选择适合的解决方法。

相关内容

热门资讯

六分钟辅助!佛手大菠萝辅助,w... 六分钟辅助!佛手大菠萝辅助,wepoker轻量版透视,教材教程(有挂头条)1)wepoker轻量版透...
第二分钟辅助!pokemmo内... 第二分钟辅助!pokemmo内置修改器,wejoker辅助软件,妙招教程(有挂详情)1、首先打开po...
第7分钟辅助!wepoker轻... 第7分钟辅助!wepoker轻量版透视系统,aapoker ai插件,绝活教程(有挂规律)1、该软件...
十分钟辅助!菠萝德州透视脚本,... 十分钟辅助!菠萝德州透视脚本,wpk可以作弊吗,项目教程(证实有挂)1、下载好菠萝德州透视脚本正确养...
六分钟辅助!wepoker有插... 六分钟辅助!wepoker有插件吗,wepoker科技辅助器,模板教程(有挂神器)1、实时wepok...
第九分钟辅助!wpk透视工作室... 第九分钟辅助!wpk透视工作室,竞技联盟透视,学习教程(真的有挂)1、wpk透视工作室有没有辅助教程...
第三分钟辅助!wepoker破... 第三分钟辅助!wepoker破解工具,购买的wpk辅助在哪里下载,妙计教程(有挂讲解)购买的wpk辅...
五分钟辅助!约局吧德州透视,拱... 五分钟辅助!约局吧德州透视,拱趴大菠萝开挂方法,策略教程(有挂方针)1、上手简单,内置详细流程视频教...
第七分钟辅助!wepoker透... 第七分钟辅助!wepoker透视挂底牌,hhpoker软件靠谱吗,妙计教程(详细教程)1、这是跨平台...
第6分钟辅助!来玩app破解版... 第6分钟辅助!来玩app破解版,hhpoker透视脚本下载,手册教程(有挂方法)1、不需要AI权限,...