0

I'm trying to get data from a local web service but I cannot print the values ​​in the app.

This is my code:

team-data.ts:

import { HttpClient } from '@angular/common/http';
import { Injectable } from '@angular/core';
import { Observable } from 'rxjs/Observable';
import { map, catchError } from 'rxjs/operators';
import 'rxjs/add/operator/map';


@Injectable()
export class TeamDataProvider {

  apiUrl="http://localhost/MyWebService/api/getteams.php";

  constructor(public http: HttpClient) {
    console.log('Hello TeamDataProvider Provider');
  }

  getTeams(): Observable<string[]> {

    return this.http.get(this.apiUrl).pipe(
      map(this.extractData),
      catchError(this.handleError)
    );

  }
  private extractData(res: Response) {
    let body = res;
    return body || {};
  }

  private handleError (error: Response | any) {
    let errMsg: string;
    if (error instanceof Response) {
      const err = error || '';
      errMsg = `${error.status} - ${error.statusText || ''} ${err}`;
    } else {
      errMsg = error.message ? error.message : error.toString();
    }
    console.error(errMsg);
    return Observable.throw(errMsg);
  }

  getRemoteData(){
    this.http.get(this.apiUrl).map(res => res).subscribe(data => {
    console.log(data);
    });
  }
}

app.module.ts:

import { BrowserModule } from '@angular/platform-browser';
import { ErrorHandler, NgModule } from '@angular/core';
import { IonicApp, IonicErrorHandler, IonicModule } from 'ionic-angular';
import { SplashScreen } from '@ionic-native/splash-screen';
import { StatusBar } from '@ionic-native/status-bar';

import { MyApp } from './app.component';
import { HomePage } from '../pages/home/home';
import { TeamDataProvider } from '../providers/team-data/team-data';
import { HttpClientModule } from '@angular/common/http';

@NgModule({
  declarations: [
    MyApp,
    HomePage
  ],
  imports: [
    BrowserModule,
    IonicModule.forRoot(MyApp),
    HttpClientModule
  ],
  bootstrap: [IonicApp],
  entryComponents: [
    MyApp,
    HomePage
  ],
  providers: [
    StatusBar,
    SplashScreen,
    {provide: ErrorHandler, useClass: IonicErrorHandler},
    TeamDataProvider
  ]
})
export class AppModule {}

home.ts:

import { TeamDataProvider } from '../../providers/team-data/team-data';
import { Component } from '@angular/core';
import { NavController, NavParams } from 'ionic-angular';

@Component({
  selector: 'page-home',
  templateUrl: 'home.html'
})
export class HomePage {

  arrayTeam: Array<any> = [];
  errorMessage: string; 

  constructor(public navCtrl: NavController, public navParams: NavParams, public teamDataProvider: TeamDataProvider) {
  }

  getTeam() {
    this.teamDataProvider.getTeams()
       .subscribe(
          teams => this.arrayTeam = teams,
          error =>  this.errorMessage = <any>error);
  }

  ionViewDidLoad(){
   this.teamDataProvider.getRemoteData();
   this.getTeam();
  } 
}

home.html:

<ion-header>
  <ion-navbar>
    <ion-title>
      Team List
    </ion-title>
  </ion-navbar>
</ion-header>

<ion-content>
  <ion-item>Team List</ion-item>
    <ion-list *ngFor="let team of arrayTeam">
      <ion-item >
        <ion-item>id: {{team.id}} name: {{team.name}} member: {{team.member}}</ion-item>
      </ion-item>
    </ion-list>
</ion-content>

What did I wrong? when i run the comand ionic serve:

Error trying to diff '[object Object]'. Only arrays and iterables are allowed

this is the date I receive from the url:

{
  "teams": [
    {
      "id": 2,
      "name": "updated",
      "member": 4
    },
    {
      "id": 3,
      "name": "cambiato",
      "member": 8
    },
    {
      "id": 4,
      "name": "test",
      "member": 3
    },
    {
      "id": 5,
      "name": "sadasd",
      "member": 2
    }
  ]
}
Charlie Lomello
  • 67
  • 2
  • 15

1 Answers1

3

You are getting an object in the response which contains an array.

You need to use that array in your subscribe:

getTeam() {
    this.teamDataProvider.getTeams()
       .subscribe(
          data => this.arrayTeam = data.teams,//here
          error =>  this.errorMessage = <any>error);
  }
Suraj Rao
  • 29,388
  • 11
  • 94
  • 103