1

我在我的 Angular (7) 应用程序中使用了材质日期选择器小部件。下面给出了html。

 <mat-form-field>
<input matInput [matDatepicker]="picker" placeholder="Expiry Date" [formControl]="expiryDateInputCtrl">
<mat-datepicker-toggle matSuffix [for]="picker"></mat-datepicker-toggle>
<mat-datepicker #picker></mat-datepicker>
<mat-hint *ngIf="isExpiryDateInvalid()" [ngStyle]="{'color': 'red'}" align="start">Invalid Expiry Date</mat-hint>

但是,这会在运行时引发以下错误。

More than one custom value accessor matches form control with unspecified name attribute
at _throwError (forms.js:2144)
at forms.js:2202
at Array.forEach (<anonymous>)
at selectValueAccessor (forms.js:2191)
at new FormControlDirective (forms.js:5042)
at createClass (core.js:22160)
at createDirectiveInstance (core.js:22029)
at createViewNodes (core.js:23255)
at createEmbeddedView (core.js:23163)
at callWithDebugContext (core.js:24177)

我使用表单控件“expiryDateInputCtrl”读取文本字段中的输入值,以检查用户是否输入了有效日期。据我所知,没有其他方法可以验证输入日期。谁能告诉我原因

4

2 回答 2

2

我发现了这个问题。我已使用 TrimValueAccessorModule 从输入控件中删除不需要的空格,这会导致此问题。下面是工作代码

<mat-form-field style="width: 100%;">
<input matInput [matDatepicker]="picker" placeholder="Expiry Date" (dateChange)="onExpiryDateChange($event)" class="ng-trim-ignore" name="expiryDate" [formControl]="expiryDateInputCtrl">
<mat-datepicker-toggle matSuffix [for]="picker"></mat-datepicker-toggle>
<mat-datepicker #picker></mat-datepicker>
<mat-hint *ngIf="isExpiryDateInvalid()" [ngStyle]="{'color': 'red'}" align="start">Invalid Expiry Date</mat-hint>

在这里添加 class="ng-trim-ignore" 解决了这个问题

于 2019-07-26T17:31:46.263 回答
1

您可以使用FormBuilderandformControlName代替[formControl]

设置你的 html :

 <form [formGroup]="tripFormGroup">
    <mat-form-field style="width: 100%">
        <input matInput [matDatepicker]="picker" placeholder="Expiry Date" 
                 formControlName="expiryDateInputCtrl">
        <mat-datepicker-toggle matSuffix [for]="picker"></mat-datepicker-toggle>
        <mat-datepicker #picker></mat-datepicker>
        <mat-hint *ngIf="isExpiryDateInvalid()" [ngStyle]="{'color': 'red'}" align="start">Invalid Expiry Date</mat-hint>
    </mat-form-field>
   ...
 </form>
于 2019-07-24T18:56:53.823 回答