1

我不清楚我应该在何时何地调用updateValueAndValidity

假设我有一个带有许多 formControls 的 formGroup。现在,基于一些单选选项选择,触发一个事件来修改多个 formControls 的“验证器”。

Q1:我是在修改后立即调用 updateValueAndValidity 还是在所有修改调用完成后调用?

Q2:我是否要通过表单更新 formGroup / formControls 以更新所有 formControls

this.form.updateValueAndValidity('emitEvent': false);

或单独调用每个 formControls

this.form.get('control1').updateValueAndValidity('emitEvent': false);
this.form.get('control3').updateValueAndValidity('emitEvent': false);
this.form.get('control8').updateValueAndValidity('emitEvent': false);
4

1 回答 1

3

您需要调用所有控件的更新以确保安全

在这个答案中https://stackoverflow.com/a/54045398/13680115你可以看到这个函数(updateValueAndValidity)更新父的行

目前它似乎正在执行以下操作(此列表基于方法名称):

  1. '设置初始状态' - 使 .status 为'有效',除非所有控件都被禁用,在这种情况下,它使其成为'禁用'
  2. '更新值' - 如果控件启用,这似乎设置 .value,如果禁用,则清除它。
  3. “运行验证器” - 这会更新整个错误对象。因此,如果您设置任何自定义错误,将被清除。
  4. “取消订阅” - 停止当时运行的任何异步验证器
  5. 'Emit' 事件 - (如果选项中的 emitEvent != false)。这只是价值和状态的正常形式事件。
  6. 使用相同的规则更新父级 - 除非设置了 onlySelf。

注意:它不会从树上下来,只会向上。

注意它不会沿着树向下走,只会向上走,所以如果你在 上调用函数formcontrols可能没有所需的行为,但更新控件将反映在表单上

因此,尽管它可能很麻烦,但您需要更新每个控件的值和有效性

于 2020-12-23T17:51:33.383 回答