使用子组件中的表单元素会引发formControlName错误

时间:2018-01-01 05:53:26

标签: angular

节日快乐的人,

请耐心等我,因为英语是我的第三语言。

我正在将一个JQuery驱动的应用程序移动到角度并陷入困境。有不同的报告相关模块依赖于日期,我想创建一个组件并导入到父组件。我的印象是调用子组件只是注入子组件模板中的任何内容,但我现在想(图片php包括函数)。

The plunkr显示了我尝试过的基本安排。但基本上,我想在其他父组件中使用日期组件。对于例如在我的父组件中我有这个:

        this.rForm = fb.group({
     'processedon': fb.group ({
        'datefilteroption' : [null, [Validators.required]],
        'dateportion' : [null, []],
        'date1': [null, []],
        'date2': [null, []]
      })
     });

其中,处理过的孩子是我孩子形式中定义的元素。子组件hmtl模板包含与它们匹配的formControlName(date1,date2等)。我可以在同一输出中有更多的日期要求,因此可以扩展如下。这个想法是子组件保持不变,该组将用于从几乎任何地方操纵其组件。

   this.rForm = fb.group({
     'processedon': fb.group ({
        'datefilteroption' : [null, [Validators.required]],
        'dateportion' : [null, []],
        'date1': [null, []],
        'date2': [null, []]
      }),
     'paidbackon': fb.group ({
        'datefilteroption' : [null, [Validators.required]],
        'dateportion' : [null, []],
        'date1': [null, []],
        'date2': [null, []]
      })
     });

我现在得到的错误是"当使用子组件"时,formControlName必须与父formGroup指令一起使用。我试图在子组件中创建一个formGroup,但后来迫使我在表单中创建一个表单并且是错误的。

我希望我的问题很明确。

1 个答案:

答案 0 :(得分:1)

解决问题的最简单方法是在您的子组件的Handler数组中提供ControlContainer

viewProviders

<强> Stackblitz Example

另见