微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

FormArray 的垂直自定义验证器

如何解决FormArray 的垂直自定义验证器

我希望总数精确到 100。但是这个验证器不起作用。我的代码有什么问题?

export class CustomValidators { 
  public static verticalTotal(total: number,refControl: string) {
    return (control: FormArray): ValidationErrors | null => {
      const arrayValue = control.value || [];
      let actualTotal = 0;
      control.controls.forEach(ctrl => {
        actualTotal += +(ctrl.get(refControl).value);
     });
  return actualTotal !== total ?
     { verticalTotal: true,message: `Total should be ${total},not ${actualTotal}`
     } : null;
    };
   } 
}

我像这样应用验证器

 this.itemForm = this.fb.group({
  subsidiaries: this.fb.array([],{
    validators: [CustomValidators.verticalTotal(100,'percent')]
  })
},{ validators: [] });

const line = this.fb.group({
  'name': ['',[]],'percent': [0,[]]
});
(this.itemForm.get('subsidiaries') as FormArray).push(line);

this.itemForm.get('subsidiaries').updateValueAndValidity();

解决方法

谢谢@Eliseo 你是对的。我的代码有效。除了我返回的对象不包含消息的定义。应该是

   {
    verticalTotal: { valid: false,message: `Total should be ${total},not ${actualTotal}`}
    } : null;

而不是我的代码中的内容。这样我就可以在组件模板中设置错误信息。

编辑:我修改的另一件事是使用值,而不是 actualTotal += +(ctrl.get(refControl).value);。这是修改后的部分

 arrayValue.forEach(ctrl => {
    actualTotal += +(ctrl[refControl]);
  });

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?