2016-10-11 16 views
2

ReactiveFormsModuleを使用して動的オブジェクトを構築しています。私のメインモジュールはです。です。次に、私はサブモジュールの設定を持っています。このコンポーネントは、ObjectConfigComponentおよびFieldConfigComponentを持ちます。Template Parse Error ngFor、FormArray

参考資料を使用して作成しましたhere この記事に記載されているプラ​​ンカーはうまくいくようです。私は私のものを動かすことができませんでした。

ここに私のコードです。

export class CompositeObject { 
    public fields: Field[]; 
} 

export class Field { 
    public name: string; 
    public datatype: DataType; 
} 

export enum DataType { 
    string = 1, 
    number, 
    date 
} 

ObjectConfigComponent

import { Component, OnInit } from '@angular/core'; 
import { CompositeObject } from './../../models/compositeobject'; 
import { Validators, FormGroup, FormArray, FormBuilder } from '@angular/forms'; 

@Component({ 
    selector: 'objectconfig', 
    templateUrl: 'objectconfig.component.html' 
}) 
export class ObjectConfigComponent implements OnInit { 
    public myForm: FormGroup; 
    constructor(private _formbuilder: FormBuilder) { } 

    public ngOnInit() { 
     this.myForm = this._formbuilder.group({ 
      fields: this._formbuilder.array([ 
       this.initField(), 
      ]) 
     }); 
    } 

    public save(model: CompositeObject) { 
     console.log(model); 
    } 

    private initField() { 
     // initialize our address 
     return this._formbuilder.group({ 
      name: ['', Validators.required], 
      datatype: ['string', Validators.required] 
     }); 
    } 

    private addField() { 
    // add address to the list 
     const control = <FormArray>this.myForm.controls['fields']; 
     control.push(this.initField()); 
    } 

    private removeField(i: number) { 
    // remove address from the list 
     const control = <FormArray>this.myForm.controls['fields']; 
     control.removeAt(i); 
    } 
} 

HTML:

<div class="row"> 
    <div class="well bs-component"> 
     <form [formGroup]="myForm" novalidate (ngSubmit)="save(myForm)"> 
      <!--fields--> 
      <div formArrayName="fields"> 
       <div *ngFor="let field of myForm.controls.fields.controls; let i=index"> 
        <div [formGroupName]="i"> 
         <fieldform [group]="myForm.controls.fields.controls[i]"></fieldform> 
        </div> 
       </div> 
      </div> 
      <div class="form-group"> 
       <div class="col-lg-10 col-lg-offset-2"> 
        <button class="btn btn-link" (click)="addField()">Add another attribute</button> 
       </div> 
      </div> 
      <div class="form-group"> 
       <div class="col-lg-10 col-lg-offset-2"> 
        <button type="reset" class="btn btn-default">Cancel</button> 
        <button type="submit" class="btn btn-primary">Submit</button> 
       </div> 
      </div> 
     </form> 
    </div> 
</div> 

FieldFormComponent

import { Component, OnInit, Input } from '@angular/core'; 
import { FormGroup } from '@angular/forms'; 
@Component({ 
    selector: 'fieldform', 
    templateUrl: 'fieldform.component.html' 
}) 
export class FieldFormComponent implements OnInit { 
    @Input('group') 
    public fieldForm: FormGroup; 
    constructor() { } 

    ngOnInit() { } 
} 

私は、次のエラーを取得しています

<div [formGroup]="fieldForm"> 
    <!-- Angular assigns array index as group name by default 0, 1, 2, ... --> 
    <div class="form-group"> 
     <!--name--> 
     <label class="col-lg-2 control-label">Attribute</label> 
     <div class="col-lg-4"> 
      <input class="form-control" id="inputName-{{i}}" type="text" formControlName="name"> 
      <!--display error message if street is not valid--> 
      <small [hidden]="fieldForm.controls.name.valid"> 
       name is required 
      </small> 
     </div> 
     <!--datatype--> 
     <div class="col-lg-4"> 
      <select class="form-control" formControlName="datatype"> 
       <option>string</option> 
       <option>number</option> 
       <option>date</option> 
      </select> 
     </div> 
    </div> 
</div> 

HTML:私が間違っているのは何

Error: Uncaught (in promise): Error: Template parse errors: Can't bind to 'ngForOf' since it isn't a known property of 'div'. ("

 <div formArrayName="fields"> 

      <div [ERROR ->]*ngFor="let field of myForm.controls.fields.controls; let i=index"> 

       <div [formGr"): [email protected]:21 Property binding ngForOf not used by any directive on an embedded 

template. Make sure that the property name is spelled correctly and all directives are listed in the "directives" section. ("

 <div formArrayName="fields"> 

      [ERROR ->]<div *ngFor="let field of myForm.controls.fields.controls; let i=index"> 

       <div [f"): [email protected]:16 

答えて

4

は、あなたのコンポーネントが含まれている@NgModule(...)

imports: [CommonModule] 

を追加します。

import { CommonModule } from "@angular/common"; 
+0

これは大丈夫ではありません...私はこれについて私の正気について質問し始めました。エラーメッセージは、何かが欠落していると思うには非常にcontra直感的なので、これらの行に沿って何かを示唆する必要があります...(私もあなたの答えの型を訂正する自由を取った - それがOKであることを望みます。) –

+0

ありがとうございました。より良いエラーメッセージを作成するのは難しいです。 'NgForOf'は他のものと同様の指示です。別のパッケージからのディレクティブを使用することもできます。 Angularに慣れた後は、このエラーメッセージが表示されたときに、何を意味し、どのように修正するかが明確になっているはずです。 –

関連する問題