构建错误
常见问题
装饰器缺少圆括号
装饰器在注解后应该带有圆括号 ()。常见示例包括:@Injectable()、@Optional()、@Input() 等。
@Directive({
selector: 'my-dir',
})
class MyDirective {
// 错误,应为 @Optional()
// 此处的 @Optional 无效,若 parent 未定义将导致 MyDirective 报错
constructor(@Optional parent: ParentComponent) {}
}
常见错误
无法解析所有参数
Cannot resolve all parameters for 'YourClass'(?). Make sure that all the parameters are decorated with Inject or have valid type annotations and that 'YourClass' is decorated with Injectable.
此异常表示 Angular 对 YourClass 构造函数中的一个或多个参数存在困惑。为了进行依赖注入,Angular 需要知道要注入参数的类型。您可以通过指定参数的类来告知 Angular。请确保:
- 已导入参数的类
- 已正确注解参数或指定其类型
import { MyService } from 'my-service'; // 别忘了导入!
@Component({
template: `Hello World`,
})
export class MyClass {
// service 的类型为 MyService
constructor(service: MyService) {}
}
有时代码中的循环引用会导致此错误。循环引用意味着两个对象相互依赖,因此无法在彼此之前声明两者。要解决此问题,可以使用 Angular 内置的 forwardRef 函数。
import { forwardRef } from '@angular/core';
@Component({
selector: 'my-button',
template: `<div>
<icon></icon>
<input type="button" />
</div>`,
directives: [forwardRef(() => MyIcon)], // MyIcon 尚未定义
}) // 当需要 MyIcon 时,forwardRef 会解析为 MyIcon
class MyButton {
constructor() {}
}
@Directive({
selector: 'icon',
})
class MyIcon {
constructor(containerButton: MyButton) {} // MyButton 已定义
}
缺少 ParamType 的提供者
No provider for ParamType! (MyClass -> ParamType)
这意味着 Angular 知道要注入的参数类型,但不知道如何注入它。
如果参数是服务,请确保已将指定类添加到 应用的提供者列表中:
import { MyService } from 'my-service';
@Component({
templateUrl: 'app/app.html',
providers: [MyService], // 别忘了添加!
})
class MyApp {}
如果参数是另一个组件或指令(例如父组件),将其添加到提供者列表会使错误消失,但这会产生与提供者多个实例相同的效果。您将创建组件类的新实例,而无法获得所需组件实例的引用。相反,请确保要注入的指令或组件对您的组件可用(例如,如果期望它是父组件,它实际上应该是父级)。通过以下示例可能更容易理解:
@Component({
selector: 'my-comp',
template: '<p my-dir></p>',
directives: [forwardRef(() => MyDir)],
})
class MyComp {
constructor() {
this.name = 'My Component';
}
}
@Directive({
selector: '[my-dir]',
})
class MyDir {
constructor(c: MyComp) {
// <-- 这是关键行
// 当指令在普通 div 上时会报错,因为组件树中没有 MyComp,所以没有可注入的 MyComp
console.log("Host component's name: " + c.name);
}
}
@Component({
template:
'<my-comp></my-comp>' + // MyDir 构造函数中无错误,MyComp 是 MyDir 的父级
'<my-comp my-dir></my-comp>' + // MyDir 构造函数中无错误,MyComp 是 MyDir 的宿主
'<div my-dir></div>', // MyDir 构造函数中报错
directives: [MyComp, MyDir],
})
class MyApp {}