Кажется, мне не удается создать переменную для представления с информацией из json-файла, но я так близко. Я могу выделить информацию в файле .subscribe()
-chain, но он не будет привязан к переменной, они просто становятся неопределенными, что я делаю неправильно?Как извлечь данные JSON из http.get в Angular 2 правильно?
Я просто хочу загрузить файл json в переменную в представлении компонента. Это было легко в Угловом 1.
Моей службы:
import { Injectable } from '@angular/core';
import { Http, Response, Headers, RequestOptions } from '@angular/http';
import 'rxjs/add/operator/map';
import {Observable} from 'rxjs/Rx';
@Injectable()
export class GullkornService {
result: any;
constructor(private http:Http) {
}
getGullkorn() {
let result = this.result;
this.http.get('./gk/gullkorn.json')
.map(res => res.json())
.subscribe(
val => this.result = val,
err => console.error(err),
() => console.log(this.result)); // this one echoes out what i want
console.log(this.result); // but this one doesnt, so i cant return it
}
}
И приземление компоненты:
import { Component, OnInit } from '@angular/core';
import {Router, RouterOutlet} from '@angular/router';
import { HttpModule, JsonpModule } from '@angular/http';
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { GullkornService } from '../../gullkorn-service.service';
import { FormsModule } from '@angular/forms';
import {Observable} from 'rxjs/Observable';
import "gsap";
declare var ease, TimelineMax,TweenMax,Power4,Power1,Power2,Power3,Bounce, Elastic:any;
@Component({
selector: 'gullkorn-visning',
providers: [GullkornService],
templateUrl: './landing.component.html',
styleUrls: ['./landing.component.css']
})
export class LandingComponent implements OnInit {
gullkorn: any;
constructor(GullkornService: GullkornService) {
this.gullkorn = GullkornService.getGullkorn();
console.log(this.gullkorn);
}
ngOnInit() {
}
}
на основе текущего кода этого является то, что я получаю:
У меня есть проект здесь: github.
СПАСИБО! Это работало с первой попытки, была для меня такой борьбой. Цените свое время много. Вызов функции с подпиской в компоненте сделал трюк! –
Добро пожаловать! Да, я понимаю. Асинхронные операции очень запутанны в начале! В моем ответе добавлен еще немного контекста, например.g, если вам нужно каким-то образом манипулировать данными в компоненте при навигации по странице, вам нужно заметить, где данные доступны в подписке, а где нет, подумал, что это может быть полезно для будущего :) Счастливое кодирование! :) – Alex