自定义组件插值



我的自定义组件是:

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>

这就行了。

最新更新