角形式 - 访问模板

时间:2017-04-20 21:25:04

标签: angular angular2-forms

我的表单中有一个嵌套控件组,我想访问它们的表单状态值(如pristine和valid)以动态显示验证错误。

像这样动态构建

controlMap['password'] = this.password;
controlMap['customData'] = this.formBuilder.group(customDataControlMap);
this.form = new FormGroup(controlMap)

来自obj就像

{
  controls:{
    password:{} 
    --->nested 
    customData:{
       controls:{
          customerId:{}
       }
    }
  }
}

模板中的ngClass看起来很丑陋

[ngClass]="( !form.controls.customData.controls.customerId.valid && !form.controls.customData.controls.customerId.touched && submitted) ? 'invalid' : ''"

并且在我尝试构建它时不会起作用(ng build --prod)

  

错误   NG:///Users/hanche/Desktop/Development/selfbits/beratergruppe-leistungen-webclient/src/app/pages/clients/client-new/client-new.component.html   (6,61):属性''控件'在类型'AbstractControl'上不存在。

1 个答案:

答案 0 :(得分:7)

试试这个

form.get('customData').get('customerId')?.invalid

form.get('customData.customerId')
  

有没有办法避免模板中的函数调用?

使用getter

class YourComponent {
  get dataCustomerId() {
    return this.form.get('customData.customerId');
  }
}

模板:

[ngClass]="dataCustomerId?.invalid"

angular forms - accessing nested controls in template