What causes the error message:
ERROR Error: Cannot find a differ supporting object '[object Object]' of type 'object'. NgFor only supports binding to Iterables such as Arrays.
and how do I fix it?
companies.json
[
{
"name": "one"
},
{
"name": "two"
},
{
"name": "three"
},
{
"name": "four"
},
{
"name": "five"
}
]
dummy-api.ts
import { Injectable } from '@angular/core';
import { Http } from '@angular/http';
import 'rxjs/add/operator/map';
import 'rxjs/add/operator/filter';
@Injectable()
export class DummyApi {
constructor(public http: Http) {}
filterCompanies(searchTerm) {
return this.http.get('assets/data/companies.json').map(res => res.json()).subscribe((data) => {
return data.filter(t=>t.name.toLowerCase().indexOf(searchTerm.toLowerCase()) > -1);
});
}
}
search.ts
import { Component } from '@angular/core';
import { FormControl } from '@angular/forms';
import { NavController } from 'ionic-angular';
import { DummyApi } from '../../providers/dummy-api/dummy-api';
import 'rxjs/add/operator/debounceTime';
@Component({
selector: 'page-search',
templateUrl: 'search.html',
providers: [DummyApi]
})
export class SearchPage {
searchTerm: string = '';
searchControl: FormControl;
companies: any;
searching: any = false;
constructor(public navCtrl: NavController, public dummyApiService: DummyApi) {
this.searchControl = new FormControl();
}
ionViewDidLoad() {
this.setFilteredCompanies();
}
setFilteredCompanies() {
this.companies = this.dummyApiService.filterCompanies(this.searchTerm);
}
}
search.html
<ion-item *ngFor="let company of companies">
{{ company.name }}
</ion-item>
.ts
file with one constant instead of a json and simply import it – mchl18