EDIT: Updated Plunkr: http://plnkr.co/edit/fQ7P9KPjMxb5NAhccYIq?p=preview
this part works:
<div *ngFor="let entry of entries | async">
Label: {{ entry.label }}<br>
Value: {{ entry.value }}
</div>
but I've problems with the select box, the error message is:
Can't bind to 'ngModel' since it isn't a known property of 'select'
The whole Component:
//our root app component
import {Component} from '@angular/core';
import {NgFor} from '@angular/common';
import {HTTP_PROVIDERS, Http} from '@angular/http';
import 'rxjs/Rx';
import {Observable} from 'rxjs/Rx';
@Component({
selector: 'my-app',
providers: [HTTP_PROVIDERS],
template: `
<select [(ngModel)]="selectValue" name="selectValue">
<option *ngFor="let entry of entries | async"
[value]="entry.value">{{entry.label}}</option>
</select>
<div *ngFor="let entry of entries | async">
Label: {{ entry.label }}<br>
Value: {{ entry.value }}
</div>
`,
directives: [NgFor]
})
export class App {
entries: any = {};
selectValue:any;
constructor(private _http: Http) {
this.entries = this._http.get("./data.json")
.map(res => res.json());
}
}
and data.json
[
{
"timestamp": 0,
"label": "l1",
"value": 1
},
{
"timestamp": 0,
"label": "l2",
"value": 2
},
{
"timestamp": 0,
"label": "l3",
"value": 3
}
]
You need to add the following to your
app.module.ts
file.And,
do the following you have to use
[ngValue]
instead of[val]
The above error is caused because you haven't imported FormsModule,ngModel is present in the FormsModule package so,to get rid of this error add
import {FormsModule} from '@angular/forms'
and add FormsModule in imports in app.module.ts class.This was happening to me in my testing suite, despite the fact that I'd already imported
FormsModule
in my component's*.module.ts
file.In my
*.component.spec.ts
file, I needed to add bothFormsModule
andReactiveFormsModule
to the imports list inconfigureTestingModule
:This fixed my case.
In app.modules.ts after
put:
And then in
insert the FormsModule something like:
>= RC.5
The
FormsModule
needs to be imported to makengModel
available<= RC.4
In
config.js
addin
main.ts
addPlunker example
See also