我的自定义组件是:
Template:
=============
<div *ngIf="!errorInput">
<div>
{{ errorMessage }}
</div>
</div>
Component
===========
import { Component, Input, OnInit } from '@angular/core';
@Component({
selector: 'app-validate',
templateUrl: './form-validate.component.html',
styleUrls: ['./form-validate.component.css'],
})
export class FormValidateComponent implements OnInit {
@Input() errorMessage: string;
@Input() errorInput: boolean;
constructor() {}
ngOnInit(): void {}
}
我正在使用上面的内容来验证表单并显示验证错误消息。
我使用这个自定义组件如下
<label>Description</label>
<input type="text" formControlName="description" pInputText
style="border-color: black;">
<app-validate
[errorInput]="isValid('description', this.formGroup)"
[errorMessage]="displayErrorMessage('description','Enter description', this.formGroup)">
</app-validate>
isValid方法基于Validator进行验证,displayErrorMessage返回错误消息。
这正在按预期进行。
在我的需求中,我必须动态生成表单组和表单字段,并对其进行验证。
我能够创建表单组、字段和验证器。
表单控件名称将根据动态值进行替换。
<div class="col-md-6"
*ngFor="let attribute of attributeList; let attributeLength = count; let attributeCount = index;">
<label> {{attribute.attributeName}}</label>
<input type="text" formControlName="{{attribute.attributeName}}" pInputText
style="border-color: black;">
<app-validate
[errorInput]="isValid('{{attribute.attributeName}}', this.formGroup)"
[errorMessage]="displayErrorMessage('{{attribute.attributeName}}','Enter as per validator ', this.formGroup)">
</app-validate>
</div>
在上面的代码{{attribute.attributeName}}中,除了以下之外,其他地方都被正确替换
<app-validate
[errorInput]="isValid(**'{{attribute.attributeName}}'**, this.formGroup)"
[errorMessage]="displayErrorMessage(**'{{attribute.attributeName}}'**,'Enter as per validator ', this.formGroup)">
</app-validate>
如果我记录isValid的第一个参数,我将获得{{attribute.attributeName}},而不是实际值。
对于自定义组件,它会被替换吗?
你能帮我解决这个问题吗?
您正在生成一个字符串,而不是使用值。这样做
<app-validate
[errorInput]="isValid(attribute.attributeName, this.formGroup)"
[errorMessage]="displayErrorMessage(attribute.attributeName,'Enter as per validator ', this.formGroup)">
</app-validate>
这就行了。