minLength和maxLength验证程序不适用于Angular7反应形式

Ric*_*ich 1 angular-validation angular angular-reactive-forms

我正在尝试使用Reactive Form在Angular7中使用Validators.minLength和Validators.maxLength,但出现以下错误:

错误错误:期望的验证程序返回Promise或Observable。

这是我的打字稿代码:

import { Component, OnInit } from '@angular/core';
import { FormGroup, FormControl, FormBuilder, Validators } from 
  '@angular/forms';

@Component({
    selector: 'app-input-values',
    templateUrl: './input-values.component.html',
    styleUrls: ['./input-values.component.css']
})

export class InputValuesComponent implements OnInit {
   inputValuesForm: FormGroup;

constructor(private fb: FormBuilder) { }

ngOnInit() {
    this.inputValuesForm = this.fb.group({
    interestRate: ['', Validators.required, Validators.minLength(2), 
       Validators.maxLength(5)]

 })
}
Run Code Online (Sandbox Code Playgroud)

这是我的模板html:

<form [formGroup]="inputValuesForm" (ngSubmit)="onSubmit()" class="form-horizontal">
  <div class="panel panel-primary">
    <div class="panel-heading">
       <h3 class="panel-title">Input Data</h3>
    </div>

    <div class="panel-body">
      <div class="form-group" [ngClass]="{'has-error': inputValuesForm.get('interestRate').errors &&
     (inputValuesForm.get('interestRate').touched || inputValuesForm.get('interestRate').dirty)}">
        <label class="col-sm-4 control-label" for="interestRate">Interest Rate (omit percent sign):</label>
        <div class="col-sm-2">
          <input id="interestRate" formControlName="interestRate" type="text" class="form-control">
          <span class="help-block" *ngIf="inputValuesForm.get('interestRate').errors &&
        (inputValuesForm.get('interestRate').touched || inputValuesForm.get('interestRate').dirty)">
           <span *ngIf=" inputValuesForm.get('interestRate').errors.required">
             Interest Rate is required
           </span>
           <span
             *ngIf="inputValuesForm.get('interestRate').errors.minlength || inputValuesForm.get('interestRate').errors.maxlength">
              Interest Rate must be greater than 1 character and less than 6 characters
           </span>
         </span>
    </div>
  </div>

    </div>
  </div>
</form>
Run Code Online (Sandbox Code Playgroud)

您知道问题出在哪里吗?

nir*_*aft 5

当您应用多个验证器时,它应该是一个数组:

ngOnInit() {
    this.inputValuesForm = this.fb.group({
    interestRate: ['', [Validators.required, Validators.minLength(2), 
       Validators.maxLength(5)]]

 })
}
Run Code Online (Sandbox Code Playgroud)

  • @Rich错误背后的原因是,FormControl构造函数的第三个可选参数接受异步验证器,即`asyncValidator?:AsyncValidatorFn | AsyncValidatorFn[] | AsyncValidatorFn[] | null` ,因此它假设 `Validators.minLength` 是一个异步验证器,这是不正确的。因此它会抛出错误 (2认同)