Показать данные из JSON, используя Angular 2 - Observable и async

У меня есть простой сервис Angular 2, который вызывает локальный файл JSON. Я могу получить объект для console.log в функции.map в general.service.ts. Однако из-за характера асинхронного вызова я не могу распечатать один ключ или значение из объекта. вот мой код

Я понимаю, что мне нужно включить * ngIf, потому что это асинхронный. Однако, хотя я использовал ngIf с 'generalInfo', который ссылается на component.ts

general.service.ts

import { Injectable } from '@angular/core';
import { Http, Response } from '@angular/http';
import { Observable } from 'rxjs/Observable';
import 'rxjs/add/operator/catch';
import 'rxjs/add/operator/map';

import { General } from '../interfaces/general.interface'

@Injectable()
export class GeneralService {
  private dataAPI = '../../assets/api.json';

  constructor(private http: Http) {

  }

  getGeneralData() : Observable<General> {
    return this.http.get(this.dataAPI)
      .map((res:Response) => { res.json(); console.log(res.json())})
      .catch((error:any) => Observable.throw(error.json().error ||     'Server error'));
  }
}

header.component.ts

import { Component, OnInit, DoCheck } from '@angular/core';
import 'rxjs/add/operator/map';
import { GeneralService } from '../../services/general.service';

@Component({
  selector: 'header',
  templateUrl: `./header.component.html`
})

export class headerComponent implements OnInit{

  public generalInfo : any;
  public name : string;

  constructor(
    private headerblock: GeneralService
  ) {}

  //Local Properties
  header;

  loadHeader() {
    this.headerblock.getGeneralData()
      .subscribe(
        generalInfo => {
          this.generalInfo = generalInfo;
          this.name = this.generalInfo.name
        },
        err => {
          console.log(err);
        }
      );

  }

  ngOnInit() {
    this.loadHeader();
  }
}

header.component.html

<div class="container">
  <div *ngIf="generalInfo">
     {{name}}
  </div>
</div>

С этим кодом, хотя на данный момент - он не входит в оператор if. Я не уверен, почему это не работает?

1 ответ

Решение

*ngIf не выполнено, причина вашего map-функция не возвращает что-то.

Так что внутри вашего subscribe-функция входящего значения undefined!

Вы должны вернуть что-то в вашей карте-функции:

.map((res:Response) => { console.log(res.json()); return res.json(); })

И в вашем шаблоне используйте его так:

{{ generalInfo.name }}

При условии, что generalInfo имеет свойство с именем name,

Другие вопросы по тегам