2017-09-30 19 views
0

私は非同期パイプとngFor指示をAngular 4.4で使用しようとしました。 それはうまく動作しますが、コンソールに奇妙なエラーメッセージが表示されます:角度4. ngForとasyncの問題

"エラー:オブジェクト 'オブジェクト'の[オブジェクトオブジェクト]が見つかりません。

<table> 
    <tbody> 
    <tr *ngFor="let event of events | async"> 
    </tr> 
    </tbody> 
</table> 


export class EventsComponent { 

    events: Observable<Array<Event>>; 

    constructor(private eventService: EventService) { 
     this.events = this.eventService.findAll(); 
    } 
} 

私はPlunkerであなたのエラーを再現

+0

'* ngFor'は配列を反復処理するだけですが、反復オブジェクトはサポートしません。 https://stackoverflow.com/questions/41396435/how-to-iterate-object-object-using-ngfor-in-angular-2/41396558#41396558 –

+2

のようなパイプを使用することができます。 findAll()によって返されるobservableは、配列ではなくオブジェクトであるように見えます。あなたが実際にそのメソッドから(実行時に)返すものを確認してください。 –

+0

まあ、findAllメソッドは、Observableの配列を返します。したがって、ngForは実際に返されたデータを表示します。唯一の問題はコンソールのエラーメッセージです。 – Sergey

答えて

1

を教えてください:

https://plnkr.co/edit/KpEnf2KOm8XJXurBTjFQ?p=preview

をエラーを作成するために、私は私のサービスメソッドが予想される配列の代わりにオブジェクトを返す作っ:

findAll(): Observable<Array<string>> { 
    return Observable.of({ data: ['Francis', 'Emilie', 'Diego'] }); 
} 

次に、コンポーネントから:すでにJB Nizetがあなたの記事下のコメントで述べ

@Component({ 
    selector: 'my-app', 
    template: ` 
    <div> 
     <ul> 
     <li *ngFor="let name of names | async">{{ name }}</li> 
     </ul> 
    </div> 
    `, 
}) 
export class App implements OnInit { 

    names: string; 

    constructor(private eventService: EventService) { } 

    ngOnInit(): void { 
    this.findAll(); 
    } 

    findAll(): void { 
    this.names = this.eventService.findAll(); 
    } 
} 

そして、私は

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

を得たとして、あなたはあなたが本当にのfindAllメソッドから返さかどうか確認する必要があります。

+0

ありがとう、Arpp。私は2つの* ngForページ(デスクトップとモバイルバージョン用)を持っていたことが判明しました。 2番目の* ngFor非同期パイプがありませんでしたので隠されましたが、まだエラーが発生しました。 – Sergey