当前位置: 首页 > 面试题库 >

Angular 5 FormGroup重置不会重置验证器

李利
2023-03-14
问题内容

我的页面上有一个表单,当我调用FormGroup.reset()它时,将forms类设置为,ng-pristine ng- untouchedFormControl.hasError(...)仍然返回true。我在这里做错了什么?

模板

<form [formGroup]="myForm" (ngSubmit)="submitForm(myForm)">
  <mat-form-field>
    <input matInput formControlName="email" />
    <mat-error *ngIf="email.hasError('required')">
      Email is a required feild
    </mat-error>
  </mat-form-field>
  <mat-form-field>
    <input matInput type="password" formControlName="password" />
    <mat-error *ngIf="password.hasError('required')">
      Password is a required feild
    </mat-error>
  </mat-form-field>
  <button type="submit">Login</button>
</form>

零件

export class MyComponent {
  private myForm: FormGroup;
  private email: FormControl = new FormContorl('', Validators.required);
  private password: FormControl = new FormControl('', Validators.required);

  constructor(
    private formBuilder: FormBuilder
  ) {
    this.myForm = formBuilder.group({
      email: this.email,
      password: this.password
    });
  }

  private submitForm(formData: any): void {
    this.myForm.reset();
  }
}

问题答案:

它(FormGroup)行为正确。您的表单需要用户名和密码,因此,当您重置表单时,该表单应该无效(即,没有用户名/密码的表单无效)。

如果我理解正确,那么这里的问题就是为什么在您第一次加载页面(表单也是无效的)时并没有出现红色错误,而是在您单击按钮时弹出了红色错误。当您使用Material时,此问题尤其突出。

AFAIK,<mat- error>请检查的有效性FormGroupDirective,而不是FormGroup,并且重置FormGroup不会重置FormGroupDirective。这有点不方便,但要清除<mat- error>您也需要重置FormGroupDirective

为此,请在模板中定义如下变量:

<form [formGroup]="myForm" #formDirective="ngForm" 
  (ngSubmit)="submitForm(myForm, formDirective)">

然后在您的组件类中,调用formDirective.resetForm()

private submitForm(formData: any, formDirective: FormGroupDirective): void {
    formDirective.resetForm();
    this.myForm.reset();
}


 类似资料:
  • 我有一个名为BigPanel的JPanel子类作为JFrame的内容窗格,在BigPanel对象中有一个嵌套的JPanel子类。单击按钮,嵌套面板应该从一个JPanel子类更改为另一个。嵌套面板没有重置,正确的子类将打印到控制台,但实际面板不会更新包com.grantbroadwater;

  • 我正在使用带有codeigniter的Ion auth库,并创建了登录、注册、记住我和忘记密码功能(到目前为止)。 对于忘记密码功能,用户输入他们的电子邮件地址,然后向他们发送一封电子邮件,其中包含重置密码的链接。 将打开一个页面,输入新密码和确认密码,当我单击“提交”时,php日志中出现以下错误: 我下载这个库时没有做任何更改,所以想知道我哪里出错了? 谢谢 下面是我的代码来支持这一点: 认证控

  • 我正在制作一个程序来修补一些文件,我想用一个作为进度指示器,但是进度条保持完全满的状态,完成后不会重置。这是更新它的方法。 我已经试过了 但当我使用它时,它根本不会显示任何进展<代码>线程。sleep()也不行。

  • 问题内容: 实用程序类中有一个静态方法,该方法将从URL下载文件。已经设置了身份验证器,以便如果需要用户名和密码,则可以检索凭据。问题是,只要凭据有效,来自第一个成功连接的凭据将用于每个连接后缀。这是一个问题,因为我们的代码是多用户的,并且由于没有为每个连接检查凭据,所以没有适当凭据的用户可能会下载文件。 这是我们正在使用的代码 第一次下载文件时,我只从getPasswordAuthenticat

  • 问题内容: //现在,我想稍后再引用InputStream,但我希望从流的开头而不是100字节开始。我尝试在100处尝试,然后在读取前100个字节后尝试了此操作,但这并没有要么工作。 有任何想法吗?可能是一个愚蠢的错误..只是没有看到它。 问题答案: 当您使用的的的java.io.InputStream对象,你应该与检查方法,如果你的InputStream实际上支持使用标记。根据API,该类不是,

  • 问题内容: 我正在使用CSS着色器+动画。我的着色器类定义如下: 我正在尝试使用jQuery通过和动态设置/取消设置样式(shader + animation) 但是,奇怪的是,当我重置类时(例如,在removeClass之后调用addClass),仅重新应用了着色器,而没有应用动画(我已钩住AnimationStart事件以查看动画何时开始)。有人知道为什么会这样吗,我该如何解决? 编辑:我在这