gpt4 book ai didi

javascript - 在 Angular Reactive Forms 中具有所需重叠的电子邮件验证

转载 作者:行者123 更新时间:2023-11-29 23:18:02 25 4
gpt4 key购买 nike

使用 Angular Reactive Forms 验证电子邮件。

我添加了 Validators Required 和 Validators Email 但它同时显示如下图所示。我只想一次显示一个错误。

enter image description here

HTML 代码:

<form [formGroup]="NamFomNgs">

<label>Email :
<input type="email" name="MylHtm" formControlName="MylNgs">
</label><br>
<div class="ErrMsgCls" *ngIf="(NamFomNgs.controls['MylNgs'].touched || NamFomNgs.controls['MylNgs'].dirty) &&
!NamFomNgs.controls['MylNgs'].valid">
<span *ngIf="NamFomNgs.controls['MylNgs'].errors.required">This field is required</span>
<span *ngIf="NamFomNgs.controls['MylNgs'].errors.email">Enter valid email</span>
</div><br>

<button [disabled]="!NamFomNgs.valid">Submit</button>
</form>

typescript 代码:

NamFomNgs:FormGroup;

constructor(private NavPkjVaj: ActivatedRoute, private HtpCncMgrVaj: HttpClient,private FomNgsPkjVaj: FormBuilder)
{
this.NamFomNgs = FomNgsPkjVaj.group(
{
MylNgs:[null,Validators.compose([
Validators.required,
Validators.email ])]
});
}

我觉得这是一个 Angular 形式的错误。

最佳答案

您可以创建通用组件来显示验证消息:

custom-validation-with-error-message

HTML:

<div *ngIf="errorMessage !== null">
{{errorMessage}}
</div>

constrol-message.component.ts:

import { OnInit } from '@angular/core';
import { Component, Input } from '@angular/core';
import { FormGroup, FormControl, AbstractControl } from '@angular/forms';

import { CustomValidationService } from '../custom-validation.service'


export class ControlMessageComponent implements OnInit {

ngOnInit() {

}
@Input() control: FormControl;

constructor() { }

/**
* This method is use to return validation errors
*/
get errorMessage() {
for (let propertyName in this.control.errors) {
if (this.control.errors.hasOwnProperty(propertyName) && this.control.touched) {
return CustomValidationService.getValidatorErrorMessage(this.getName(this.control), propertyName, this.control.errors[propertyName]);
}
if (this.control.valueChanges) {
return CustomValidationService.showValidatorErrorMessage(propertyName, this.control.errors[propertyName])
}
}
return null;
}

/**
* This method used to find the control name
* @param control - AbstractControl
*/
private getName(control: AbstractControl): string | null {
let group = <FormGroup>control.parent;

if (!group) {
return null;
}
let name: string;
Object.keys(group.controls).forEach(key => {
let childControl = group.get(key);
if (childControl !== control) {
return;
}
name = key;
});
return name;
}
}

关于javascript - 在 Angular Reactive Forms 中具有所需重叠的电子邮件验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51917729/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com