我读过几篇关于依赖注入的文章,似乎无法让它像我认为的那样工作。根据我所读到的,您可以在类上使用@Injectable装饰器,然后为DI创建元数据,如下所示:
import {Hero} from './hero.model';
import {Injectable} from 'angular2/angular2'
@Injectable()
export class HeroService {
constructor() {
console.log('Hero Service Created');
}
}然后,在组件中,您可以在构造函数中使用它(通过适当的导入),如下所示:
constructor(heroService: HeroService) {
console.log('App Component Created');
}但是,我得到以下错误:无法解析AppComponent(?)的所有参数。确保它们都有有效的类型或注释。
如果我从服务中删除@Injectable语法,并让构造函数如下所示,我就能够使它正常工作:
constructor(@Inject(HeroService) heroService: HeroService) {
console.log('App Component Created');
}对于我所读到的所有东西,它们应该做同样的事情,但它们不是。有什么想法吗?我使用的是打字本1.6.2和VS 2013,角形2 v2.0.0-alpha.46 .46和systemjs v0.19.5。
发布于 2015-11-13 19:53:50
确保在您的emitDecoratorMetadata配置中指定了“TypeScript”选项。
https://stackoverflow.com/questions/33700446
复制相似问题