import { Component,OnInit} from '@angular/core'; import { Observable } from 'rxjs/Observable'; import { Http, Response } from '@angular/http'; import 'rxjs/add/operator/catch'; import 'rxjs/add/operator/map'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent implements OnInit { title = 'app works!'; private apiUrl = '/api/values';//'http://localhost:7667/api/values'; // URL to web API constructor (private http: Http) {} ngOnInit() { this.getValues().subscribe(r=> {}); } getValues (): Observable<any[]> { return this.http.get(this.apiUrl) .map(this.extractData) .catch(this.handleError); } private extractData(res: Response) { let body = res.json(); console.log(body); return body.data || { }; } private handleError (error: Response | any) { // In a real world app, we might use a remote logging infrastructure let errMsg: string; if (error instanceof Response) { const body = error.json() || ''; const err = body.error || JSON.stringify(body); errMsg = `${error.status} - ${error.statusText || ''} ${err}`; } else { errMsg = error.message ? error.message : error.toString(); } console.error(errMsg); return Observable.throw(errMsg); } }