首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >解决承诺时Angular2错误:键入'Promise<Hero[]>‘不能指定键入'Hero[]’

解决承诺时Angular2错误:键入'Promise<Hero[]>‘不能指定键入'Hero[]’
EN

Stack Overflow用户
提问于 2017-05-26 13:27:56
回答 1查看 1.3K关注 0票数 1

已更新。

我正在学习来自Angular2的https://angular.io/docs/ts/latest/tutorial/toh-pt4.html教程

下面是来自HeroService的heroes.component.ts调用,

Heroes.component.ts

代码语言:javascript
复制
import { Component , OnInit } from '@angular/core';

import { Hero } from './hero';

import { HeroService } from './hero.service';



@Component({
  selector: 'my-heroes',
  template: `


        <h2>My Heroes</h2>
        <ul class="heroes">
            <li *ngFor="let hero of heroes">
                 <span class="badge">{{hero.id}}</span> {{hero.name}}
            </li>
         </ul> `,

})

export class HeroesComponent implements OnInit {
    title = 'Tour of Heroes';
    heroes: Hero[];
    selectedHero: Hero;

    constructor(private heroService : HeroService ){

    }

    getHeroes(): void{
      this.heroService.getHeroes().then(heroes => this.heroes = heroes);
    }

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


}

和用getHeroes()编写的HeroService调用

HeroService.ts

代码语言:javascript
复制
import { Injectable } from '@angular/core';
import { Hero } from './hero';
import { HEROES } from './mock-heroes';

@Injectable()
export class HeroService{
    getHeroes() { 
       return Promise.resolve(HEROES);
     }
}

我得到以下编译时错误:

错误TS2322:键入‘承诺’不能指定为键入'Hero[]‘。属性“长度”在“允诺”类型中缺失。

请建议一下。

EN

回答 1

Stack Overflow用户

发布于 2017-08-28 10:47:16

heroes: Hero[];更改为heroes: any;解决了这个问题,但是控制台返回一个错误,因为ngFor只支持iterables。最后,代码编译和应用程序运行,但有一个小问题,我发现干扰。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44202862

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档