2016-07-09 26 views
10

jsonファイルから国を取得してドロップダウンにバインドするための非常に小さなアプリケーションを作成しました。Angular2:タイプ 'Subscription'がタイプに割り当てられません

countries.json

export class Country { 
    id: number; 
    name: string; 
} 

factory.service.ts

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

import { Country } from './shared/country'; 

@Injectable() 
export class FactoryService { 
    private countryUrl = "app/data/countries.json"; 

    constructor(private http: Http) { 

    } 

    getCountry(): Observable<any> { 
     return this.http.get(this.countryUrl) 
      .map(this.extractData) 
      .do(data => console.log("get Countries from json: " + JSON.stringify(data))) 
      .catch(this.handleError); 
    } 

    private extractData(response: Response) { 
     let body = response.json(); 
     return body || {}; 
    } 

    private handleError(error: Response) { 
     console.log(error); 
     return Observable.throw(error.json().error || "500 internal server error"); 
    } 
} 

factory-form.component.ts

import { Component, OnInit } from '@angular/core'; 
import { NgForm } from '@angular/forms'; 

import { Factory } from './factory'; 
import { Country } from './shared/country'; 
import { FactoryService } from './factory.service'; 

@Component({ 
    moduleId: module.id, 
    selector: 'factory-form', 
    templateUrl: './factory-form.component.html', 
    styleUrls: ['./factory-form.component.css'], 
    providers: [FactoryService] 
}) 
export class FactoryFormComponent implements OnInit{ 

    private model: Factory; 
    countries: Country[]; 
    factoryStatuses; 
    productTypes; 
    risks; 
    private errorMessage: string; 
    private submitted = false; 

    constructor(private factoryService: FactoryService) { 

    } 

    ngOnInit(): void { 
     this.countries = this.factoryService.getCountry() 
      .subscribe(countries => this.countries = countries, 
      error => this.errorMessage = error); 
    } 

    onSubmit(): void { 
     this.submitted = true; 
    }} 

factory-form.component.html snippet

<div class="col-lg-3"> 
      <select class="form-control" name="Country"> 
       <option *ngFor="let country of countries" [value]="country.id">{{country.name}}</option> 
      </select> 
     </div> 

私は以下のようにランタイムエラーを取得しています私は観察可能国いずれかにの種類を変更した場合は

Error: Typescript found the following errors:
C:/Projects/ethical_resourcing/src/Ethos.Client/tmp/broccoli_type_script_compiler-input_base_path-kviWq7F3.tmp/0/src/app/factory/factory-form.component.ts (30, 9): Type 'Subscription' is not assignable to type 'Country[]'.
Property 'length' is missing in type 'Subscription'.
C:/Projects/ethical_resourcing/src/Ethos.Client/tmp/broccoli_type_script_compiler-input_base_path-kviWq7F3.tmp/0/src/app/factory/shared/country.ts (2, 15): ';' expected. at BroccoliTypeScriptCompiler._doIncrementalBuild (C:\Projects\ethical_resourcing\src\Ethos.Client\node_modules\angular-cli\lib\broccoli\broccoli-typescript.js:120:19) at BroccoliTypeScriptCompiler.build (C:\Projects\ethical_resourcing\src\Ethos.Client\node_modules\angular-cli\lib\broccoli\broccoli-typescript.js:43:10) at C:\Projects\ethical_resourcing\src\Ethos.Client\node_modules\angular-cli\node_modules\broccoli-caching-writer\index.js:152:21 at lib$rsvp$$internal$$tryCatch (C:\Projects\ethical_resourcing\src\Ethos.Client\node_modules\angular-cli\node_modules\rsvp\dist\rsvp.js:1036:16) at lib$rsvp$$internal$$invokeCallback (C:\Projects\ethical_resourcing\src\Ethos.Client\node_modules\angular-cli\node_modules\rsvp\dist\rsvp.js:1048:17) at lib$rsvp$$internal$$publish (C:\Projects\ethical_resourcing\src\Ethos.Client\node_modules\angular-cli\node_modules\rsvp\dist\rsvp.js:1019:11) at lib$rsvp$asap$$flush (C:\Projects\ethical_resourcing\src\Ethos.Client\node_modules\angular-cli\node_modules\rsvp\dist\rsvp.js:1198:9) at nextTickCallbackWith0Args (node.js:420:9) at process._tickCallback (node.js:349:13)

は今、私はエラー

ORIGINAL EXCEPTION: Cannot find a differ supporting object '[object Object]' of type 'object'. NgFor only supports binding to Iterables such as Arrays.

答えて

10

はい、タイプでなければなりませんObservableの下に取得し、あなたがする非同期パイプを使用する必要があります

*ngFor="let country of countries | async" 

するか、別のオプションは、Country[]タイプを維持することですが、その後加入しを割り当てる:ngForを幸せにしますは、アレイへ:

this.factoryService.getCountry() // note, removed this.countries = 
    .subscribe(
     countries => this.countries = countries, 
     error => this.errorMessage = error 
    ); 
+0

は、この例外が発生しました:パイプの無効な引数「[オブジェクトのオブジェクト]」「AsyncPipe」 –

+0

私は非同期パイプを削除し、あなたの提案を試してみました。それはエラーを修正した。なぜthis.countriesがエラーを出していたのですか?基本的に私はPluralsightのビデオにちょうど従っていて、彼女のために働いていました。彼女はベータ版を使用していましたが、私はrc.4を使用しています。私は3時間を無駄にしました:( –

+0

なぜそれがgivignエラーであったのかを教えてください。 –

関連する問題