我正在使用 angular 8 和 angular 材料来编写我的网站。
我有一个formGroup
创建的表单,我希望能够*ngIf
通过使用实际输入元素作为参数来检查验证错误。
目前这是我的工作代码:
我有以下表格:
<form [formGroup]="queryForm" (submit)="runQuery()">
...
<mat-form-field>
<input matInput #timezone placeholder="Timezone" aria-label="Timezone" formControlName="timePeriodTimeZone"/>
<mat-hint>timezone as a number</mat-hint>
<mat-error *ngIf="hasError('timePeriodTimeZone','required')">timezone required</mat-error>
</mat-form-field>
...
</form>
在组件的类中,我实现了hasError()
这样的功能:
public hasError = (controlName: string, errorName: string) =>{
return this.queryForm.controls[controlName].hasError(errorName);
}
当然,我将queryForm
变量配置为由表单生成器创建的组。
有没有办法在不从类本身调用函数的情况下检查错误?
因为我添加#timezone
到输入字段中,所以我认为我将能够执行以下操作:
<mat-error *ngIf="timezone.hasError('required')">timezone required!</mat-error>
但我不能!:)
我更喜欢使用类似的东西,因为我想创建一个带有一些 mat-errors 的错误处理组件,因此我将能够在每个输入字段中重用它,并且我想将输入控件而不是整个表单粘贴到它团体。
任何有关此问题的信息将不胜感激。
谢谢!