我创建了一个简单的Hello World应用程序。但是当我想添加一个“服务”只是一个简单的Di时,我得到了以下错误:
angular2.dev.js:23877 EXCEPTION:无法解析'AppComponent'(?)的所有参数。确保所有参数都使用Inject进行修饰或具有有效的类型注释,并且'AppComponent'使用Injectable进行修饰。
angular2-polyfills.js:469未处理的承诺拒绝:无法解析'AppComponent'(?)的所有参数。确保所有参数都使用Inject进行修饰或具有有效的类型注释,并且“AppComponent”使用Injectable进行修饰。 ;区域:角;任务:Promise.then;价值:
我有3个档案
boot.ts:
///<reference path="../../node_modules/angular2/typings/browser.d.ts"/>
import {bootstrap} from 'angular2/platform/browser'
import {AppComponent} from './mainApp'
bootstrap(AppComponent);
mainApp.ts:
import {Component} from 'angular2/core';
import {CourseService} from './course.service';
@Component({
selector: 'my-app',
template: 'My First Angular 2 App',
providers: [CourseService],
})
export class AppComponent {
constructor(courseService: CourseService) {
}
}
course.service.ts:
export class CourseService {
public getCourses(): string[] {
let courses: string[] = ["Course 1", "Course 2", "Course 3"];
return courses;
}
}
当我从构造函数中删除参数时,每个东西都可以正常工作。
这就是我的HTML文档的头部,我使用的是角度2 beta 13:
<script src="~/Scripts/es6-shim.min.js"></script>
<script src="~/Scripts/system-polyfills.js"></script>
<script src="~/Scripts/shims_for_IE.js"></script>
<script src="~/Scripts/angular2-polyfills.js"></script>
<script src="~/Scripts/system.js"></script>
<script src="~/Scripts/Rx.js"></script>
<script src="~/Scripts/angular2.dev.js"></script>
<!-- 2. Configure SystemJS -->
<script>
System.config({
packages: {
'ScriptsApp/views': {
defaultExtension: 'js'
}
}
});
</script>
<script>
System.import('ScriptsApp/views/boot').then(null, console.error.bind(console));
</script>
现在更新这些是我的固定csproj TypeScript设置
<TypeScriptTarget>ES5</TypeScriptTarget>
<TypeScriptJSXEmit>None</TypeScriptJSXEmit>
<TypeScriptCompileOnSaveEnabled>True</TypeScriptCompileOnSaveEnabled>
<TypeScriptNoImplicitAny>False</TypeScriptNoImplicitAny>
<TypeScriptModuleKind>CommonJS</TypeScriptModuleKind>
<TypeScriptRemoveComments>False</TypeScriptRemoveComments>
<TypeScriptOutFile />
<TypeScriptOutDir />
<TypeScriptGeneratesDeclarations>False</TypeScriptGeneratesDeclarations>
<TypeScriptNoEmitOnError>True</TypeScriptNoEmitOnError>
<TypeScriptSourceMap>True</TypeScriptSourceMap>
<TypeScriptMapRoot />
<TypeScriptSourceRoot />
<TypeScriptExperimentalDecorators>True</TypeScriptExperimentalDecorators>
<TypeScriptEmitDecoratorMetadata>True</TypeScriptEmitDecoratorMetadata>
在最新的VS 2015更新中,您还可以使用tsconfig.json,然后忽略TypeScript的解决方案设置。我目前的tsconfig.json示例:
{
"compilerOptions": {
"target": "es5",
"module": "commonjs",
"moduleResolution": "node",
"sourceMap": true,
"emitDecoratorMetadata": true,
"experimentalDecorators": true,
"removeComments": false,
"noImplicitAny": false,
//Kümmert sich um die Typings das diese entsprechend gefunden werden, keine Reference mehr in boot.js notwendig. Geht aber in VS nicht!
//"lib": ["es6"],
"types": [
"node" //wird für RequireJs benötigt, damit z.b. der Typ gefunden werden kann
]
},
//Wird für den AwesomeTypeScriptLoad in WebPack benötigt!
"awesomeTypescriptLoaderOptions": {
"useWebpackText": true
},
"exclude": [
"node_modules",
"dist",
"typings/main",
"typings/index.d.ts"
],
"compileOnSave": true
}
答案 0 :(得分:30)
<强>更新强>
有问题的更新OP已经使用了Typescript,我建议您在emitDecoratorMetadata: true
内添加tsconfig.json
。因此JavaScript输出必须为已编译的脚本文件中的装饰器创建元数据。
您需要添加@Inject
以在CourseService
AppComponent
的实例
constructor(@Inject(CourseService) courseService: CourseService) {
}
如果您使用打字稿,则不需要在那里安装@Inject
装饰器。打字稿为你完成了。
答案 1 :(得分:9)
我能够通过添加:
来解决这个问题import {Inject} from '@angular/core';
在组件中并注释要注入的服务:
constructor(@Inject(CourseService) courseService: CourseService) {
答案 2 :(得分:0)
在我的情况下,问题是由@ angular / forms引起的。如果您在故障组件附近使用它,请开始检查@ angular / forms并找到它周围的修复。