Optional

From Get docs
< @angular/coreAngular/docs/8/api/core/optional


Optional

decorator

Parameter decorator to be used on constructor parameters, which marks the parameter as being an optional dependency. The DI framework provides null if the dependency is not found.

See more...

Description

Can be used together with other parameter decorators that modify how dependency injection operates.

Learn more in the "Dependency Injection Guide".

Options

Usage notes

The following code allows the possibility of a null result:

class Engine {}

@Injectable()
class Car {
  constructor(@Optional() public engine: Engine) {}
}

const injector =
    Injector.create({providers: [{provide: Car, deps: [[../new Optional(), Engine]]}]});
expect(injector.get(Car).engine).toBeNull();

© 2010–2020 Google, Inc.
Licensed under the Creative Commons Attribution License 4.0.
https://v8.angular.io/api/core/Optional