Inject
decorator
A parameter decorator on a dependency parameter of a class constructor that specifies a custom provider of the dependency.
Option | Description |
---|---|
token |
A DI token that maps to the dependency to be injected. |
Description
Learn more in the "Dependency Injection Guide".
Options
token |
---|
A DI token that maps to the dependency to be injected. |
|
Usage notes
The following example shows a class constructor that specifies a custom provider of a dependency using the parameter decorator.
class Engine {} @Injectable() class Car { constructor(@Inject('MyEngine') public engine: Engine) {} } const injector = ReflectiveInjector.resolveAndCreate([{provide: 'MyEngine', useClass: Engine}, Car]); expect(injector.get(Car).engine instanceof Engine).toBe(true);
When @Inject()
is not present, the injector uses the type annotation of the parameter as the provider.
class Engine {} @Injectable() class Car { constructor(public engine: Engine) { } // same as constructor(@Inject(Engine) engine:Engine) } const injector = ReflectiveInjector.resolveAndCreate([Engine, Car]); expect(injector.get(Car).engine instanceof Engine).toBe(true);
© 2010–2019 Google, Inc.
Licensed under the Creative Commons Attribution License 4.0.
https://v7.angular.io/api/core/Inject