Resolution modifiers : Angular dependency injection resolution mechanism of the service starts from component and stops either when a service is found or NUllInjector is reached. This is the default resolution and it can be changed using Resolution Modifier.
Table of Contents
Resolution modifiers fall into three categories.
@Optional()
@Self()
@SkipSelf()
@Host()
@Optional() allows Angular to consider a service you inject to be optional and does not throws the error when the search for the service fails.
@Self is used, Angular will only look for a value that is bound on the component injector for the element that this Directive/Component exists on.
data:image/s3,"s3://crabby-images/73a27/73a27f7b9c010d7d4b618e97bf2e0363b2f29cae" alt="@self() self resolution modifiers"
@Host is used, Angular will look for a value that is bound on either the component injector for the element that this Directive/Component exists on, or on the injector of the parent component. Angular calls this parent component the “host”.
data:image/s3,"s3://crabby-images/08aa0/08aa057c2f56048647aba03a87748668702991e9" alt="host resolution modifiers"
data:image/s3,"s3://crabby-images/9559c/9559c2b44ca4e269c0d0db7318467289ffbb8d11" alt="skipself resolution modifiers"
Related Post
Source code available for download
The source code is available on Stackblitz of the Angular Dependency Injection – Resolution modifiers – @Self or @Optional @Host
Demo Application URL: URL or download the project sources from https://stackblitz.com/edit/inject-and-injectable-qwnzso