如何基于Angular 6中的用户输入显示不同的错误消息

时间:2018-09-19 05:34:27

标签: angular typescript angular-material angular6

我是角度6的新手,在这里我想验证用户输入字段并根据给定的输入显示不同的错误消息。

在我的项目中,我将Angular Material设计用于UI。

我想做的是

  • 如果用户单击“保存”按钮,则会显示错误消息,显示为“请输入您的FName”。
  • 如果用户触摸但未输入任何东西,然后单击“保存”按钮,则会显示错误消息,显示为“请输入您的FName”。
  • 如果用户开始输入char,它将显示一条错误消息,显示为“最少需要4个char”
  • 一旦用户达到15个字符,它应该显示一条错误消息,显示为“最多20个字符”
  • 如果用户输入任何特殊的字符和空格,而其他用户输入的错误消息为“仅输入字母”

现在,当输入不符合成功的验证时,它将变为红色。但是我想在formControl中为每个验证显示一条错误消息。

这里有一个mat-input-field。

<form [formGroup]="userAddressValidations" novalidate>
    <mat-form-field appearance="outline" class="col-sm-6">
        <mat-label>First Name</mat-label>
        <input matInput formControlName="firstName">
    </mat-form-field>
</form>

<button mat-raised-button class="continueBtnHeight" color="warn">
<span>Save</span>
</button>

Ts文件

export class ButtonToggleOverviewExample {
  userAddressValidations: FormGroup;
  constructor(private formBuilder: FormBuilder) { }
  ngOnInit() {
    this.userAddressValidations = this.formBuilder.group({
      firstName: ['', [Validators.required, Validators.minLength(4), Validators.maxLength(20), Validators.pattern('[a-zA-Z]+')]]
    });

  }
}

stackblitz:https://stackblitz.com/edit/angular-t1k1x6-skowwq?file=app%2Fbutton-toggle-overview-example.ts

谁能帮我解决这个问题。

3 个答案:

答案 0 :(得分:2)

尝试一下:

<form class="example-form" [formGroup]="userAddressValidations">
  <mat-form-field class="example-full-width">
    <input matInput placeholder="First Name" formControlName="firstName">
    <mat-error *ngIf="userAddressValidations.get('firstName').hasError('required')">
      First Name is Required!
    </mat-error>
    <mat-error *ngIf="userAddressValidations.get('firstName').hasError('minlength')">
      First Name should be atleast 4 characters long!
    </mat-error>

    <mat-error *ngIf="userAddressValidations.get('firstName').hasError('maxlength')">
      First Name can be atmax n characters long!
    </mat-error>

    <mat-error *ngIf="userAddressValidations.get('firstName').hasError('pattern')">
      First Name must follow this pattern!
    </mat-error>
  </mat-form-field>

</form>

这是您推荐的Sample StackBlitz

答案 1 :(得分:1)

如果用户输入任何特殊字符和空格,请使用hasError('invalidName')

Stackblitz

  

Component.html

<form [formGroup]="userAddressValidations">

    <label>User Name : 
        <input type="text"  formControlName="firstName">
    </label><br>

    <div class="errors" *ngIf="userAddressValidations.get('firstName').invalid && (userAddressValidations.get('firstName').touched || userAddressValidations.get('firstName').dirty)">

        <div *ngIf="userAddressValidations.get('firstName').hasError('required')">
            Please enter your FName
        </div>

        <div *ngIf="userAddressValidations.get('firstName').errors.minlength">
            minimum 4 char required
        </div>

        <div *ngIf="userAddressValidations.get('firstName').errors.maxlength">
            Maximum 20 char only
        </div>

        <div class="error-text" *ngIf="userAddressValidations.get('firstName').hasError('invalidName')">
            Enter only alphabets
        </div>
    </div>

</form>
  

Component.ts

this.userAddressValidations = fb.group({
      firstName: ['', [Validators.required, Validators.minLength(4), Validators.maxLength(20), usernameValidator]]
});
  

username.validators.ts

import { AbstractControl, ValidationErrors } from "@angular/forms"

export const usernameValidator = function (control: AbstractControl): ValidationErrors | null {

  let value: string = control.value || '';

  if (value) {
    const matches = value.match(/^[a-zA-Z]+$/);
    return matches ? null : { 'invalidName': true };
  } else {
    return null;
  }
}

答案 2 :(得分:0)

看一下本教程https://codecraft.tv/courses/angular/forms/model-driven-validation,您也可以参考以下stackoverflow问题:Display custom validator error with mat-error

但这是一个小例子:

<form [formGroup]="userAddressValidations" novalidate>
    <mat-form-field appearance="outline" class="col-sm-6">
        <mat-label>First Name</mat-label>
        <input matInput formControlName="firstName">
         <mat-error *ngIf="email.errors.required">{{getErrorMessage()}}</mat-error>
         <mat-error *ngIf="email.errors.minlength">{{getErrorMessage()}}</mat-error>
    </mat-form-field>
</form>