2016-11-02 6 views
0

私はangularjs 2を学び、サービスの使い方を理解し、それを私のアプリケーションで使えるようにしています。だから私の目標は私のモックからデータを取得しているサービスを使用してangularjs 2でデータを入力

film.services.ts

import { Injectable } from "@angular/core"; 

import { Film } from './film'; 
import { FILMS } from './mock-films'; 

@Injectable() 
export class FilmService { 
    getFilms(): Promise<Film[]> { 
    return Promise.resolve(FILMS) 
    } 
} 

モックフィルム

import { Film } from './film'; 

//storing the data in array 
export const FILMS: Film[] = [ 
    {id:11, title: 'pokemon', summary:'great'}, 
    {id:12, title: 'naruto', summary: 'good'}, 
    {id:13, title: 'bleach', summmary: 'meh'}, 
    {id:14, title: 'one piece', summary: 'not bad'} 
]; 

フィルムlist.components.ts

import { Component, OnInit } from '@angular/core'; 
import { Observable } from 'rxjs/Observable' 
import { FilmService } from '../film.service'; 
import { Film } from "../film"; 

@Component({ 
    template: ` 
    <h1>List of Films</h1> 
    <p>Films:</p> 
    <ul> 
    <li *ngFor="let film of films "> 
    <a [routerLink]="['/films', film.id]">{{film.title}}</a> 
     </li> 
    </ul> 
    <p *ngIf="films.length > 3">There are many vietnamese films to learn about!</p> 
`, 
    // important when adding to service other crashes 
    providers: [FilmService] 
}) 

//Component class 
export class FilmListComponent implements OnInit { 
    public films: Film[]; 
    constructor(private filmService: FilmService) {} 

    getFilms(){ 
    this.filmService.getFilms().then((films: Film[]) => this.films = films); 
    } 

    ngOnInit():any { 
    this.getFilms() 
    } 
} 

映画は私の映画リストに入っていますが、何らかの理由で表示されません。それはおそらくfilm-list.component.tsですが、どこにエラーがあるのか​​わかりません。

+0

私はあなたが取得しているどのようなエラーを知ってもいいですか? –

答えて

1

ここ

public films: Film[]=[]; 

OR

public films: Film[]; 
    constructor(private filmService: FilmService) {} 
    getFilms(){ 
     this.flims=[]; 
     this.filmService.getFilms().then((films: Film[]) => this.films = films); 
     } 

フィルムlist.components.tsで修正

import { Component, OnInit } from '@angular/core'; 
import { Observable } from 'rxjs/Observable' 
import { FilmService } from '../film.service'; 
import { Film } from "../film"; 

@Component({ 
    template: ` 
    <h1>List of Films</h1> 
    <p>Films:</p> 
    <ul> 
    <li *ngFor="let film of films "> 
    <a [routerLink]="['/films', film.id]">{{film.title}}</a> 
     </li> 
    </ul> 
    <p *ngIf="films.length > 3">There are many vietnamese films to learn about!</p> 
`, 
    // important when adding to service other crashes 
    providers: [FilmService] 
}) 

//Component class 
export class FilmListComponent implements OnInit { 

    public films: Film[]; 
    constructor(private filmService: FilmService) {} 

    getFilms(){ 

    this.flims=[];//fix in here 
    this.filmService.getFilms().then((films: Film[]) => this.films = films); 
    } 

    ngOnInit():any { 
    this.getFilms() 
    } 
} 
+0

ありがとうございます。それがなぜ効果があるのか​​説明できますか?私はそれをよく理解していますか? – user3296193

+0

公開映画:映画[] = [];あなたはこのようなものが何であるかを知る必要があります。例:public flim:string = "";このように宣言すると、Flim []はこれを定義しません。 –

関連する問題