SlideShare a Scribd company logo
DEPENDENCY
INJECTION
ANGULAR
DEEP-DIVE
TANAKRIT
SAISILLAPEE
WEB COMPONENT THAILAND,
ZAREWOFT
constructor(private user: UserService)
constructor(@Inject(UserService) public user: UserService)
constructor(private user: UserService)
constructor(private user: UserService)
constructor(private user: UserService)
Angular Dependency Injection
new AppComponent(userService);
new AppComponent(userService);
?
Angular Dependency Injection
Angular Dependency Injection
Angular Dependency Injection
Angular Dependency Injection
RootInjectorAppModule
Angular Dependency Injection
AppModule RootInjector
AppModule RootInjector
providers: [ UserService ]
AppModule RootInjector
providers: [ UserService ]
BrowserModule providers
FontAwesomeModule
providers
AppModule RootInjector
providers: [ UserService ]
BrowserModule providers
FontAwesomeModule
providers
providers: [ UserService ]
BrowserModule providers
FontAwesomeModule providers
AppModule RootInjector
providers: [ UserService ]
AppComponent
constructor(user: UserService)
BrowserModule providers
FontAwesomeModule
providers
providers: [ UserService ]
BrowserModule providers
FontAwesomeModule providers
AppModule RootInjector
providers: [ UserService ]
AppComponent
constructor(user: UserService)
BrowserModule providers
FontAwesomeModule
providers
providers: [ UserService ]
BrowserModule providers
FontAwesomeModule providers
UserService
AppModule RootInjector
providers: [ UserService ]
AppComponent
constructor(user: UserService)
BrowserModule providers
FontAwesomeModule
providers
providers: [ UserService ]
BrowserModule providers
FontAwesomeModule providers
UserService
AppModule RootInjector
providers: [ UserService ]
AppComponent
constructor(user: UserService)
BrowserModule providers
FontAwesomeModule
providers
providers: [ UserService ]
BrowserModule providers
FontAwesomeModule providers
UserService
BlaComponent
constructor(user: UserService)
AppModule RootInjector
providers: [ UserService ]
AppComponent
constructor(user: UserService)
BrowserModule providers
FontAwesomeModule
providers
providers: [ UserService ]
BrowserModule providers
FontAwesomeModule providers
UserService
BlaComponent
constructor(user: UserService)
AppModule RootInjector
providers: [ UserService ]
AppComponent
constructor(user: UserService)
BrowserModule providers
FontAwesomeModule
providers
providers: [ UserService ]
BrowserModule providers
FontAwesomeModule providers
UserService
BlaComponent
constructor(user: UserService)
Angular Dependency Injection
Angular Dependency Injection
AppComponent
constructor(user: UserService)
Component C
RootComponentInjector (A)
ParentInjector (B)
ChildInjector (C)
Component Tree Injector Tree
Component A
Component B
Angular Dependency Injection
AppModule
AppComponen
Component C
Component A
Component B
RootComponentInjector (A)
ParentInjector (B)
ChildInjector (C)
RootInjector
AppModule
AppComponen
Component C
Component A
Component B
RootComponentInjector (A)
ParentInjector (B)
ChildInjector (C)
RootInjector
LazyLoadModule
Component C
Component A
Component B
RootComponentInjector
(A)
ParentInjector (B)
ChildInjector (C)
LazyLoadRootInjector
Angular Dependency Injection
Angular Dependency Injection
AppModule
AppComponen
Component C
Component A
Component B
RootComponentInjector (A)
ParentInjector (B)
ChildInjector (C)
RootInjector
LazyLoadModule
Component C
Component A
Component B
RootComponentInjector
(A)
ParentInjector (B)
ChildInjector (C)
LazyLoadRootInjector
AppModule
AppComponen
Component C
Component A
Component B
RootComponentInjector (A)
ParentInjector (B)
ChildInjector (C)
RootInjector
LazyLoadModule
Component C
Component A
Component B
RootComponentInjector
(A)
ParentInjector (B)
ChildInjector (C)
LazyLoadRootInjector
PlatformInjector
Angular Dependency Injection
• @Injectable() Tree-Shakable
• @Injectable() Tree-Shakable
• @NgModule Import, Lazy
• @Injectable() Tree-Shakable
• @NgModule Import, Lazy
• @Component Hierarchical

@Directive
Beware of provider declaration
Reference
• https://angular.io/guide/hierarchical-dependency-injection
• https://angular.io/guide/dependency-injection-providers
• https://angular.io/guide/providers
• https://angular.io/guide/singleton-services
• https://angular.io/guide/lazy-loading-ngmodules

More Related Content

PPTX
Angular 9
PPTX
Flutter vs React: взгляд нативщика / Александр Смирнов (Splyt)
PPT
Angular Seminar-js
PDF
Angular JS Introduction
PPTX
Angular interview questions
PPTX
Creating a custom connector in mule
PDF
Full Angular 7 Firebase Authentication System
PPTX
Mule Integration with Atlassian JIRA
Angular 9
Flutter vs React: взгляд нативщика / Александр Смирнов (Splyt)
Angular Seminar-js
Angular JS Introduction
Angular interview questions
Creating a custom connector in mule
Full Angular 7 Firebase Authentication System
Mule Integration with Atlassian JIRA

What's hot (17)

PDF
Introduction to Vaadin
PDF
Firebase. Предмет и область применения — Тимур Ахметгареев
PDF
Introduction To Angular 4 - J2I
PDF
Angular material tutorial
PPTX
OAuth Authorization flows in salesforce
PPTX
Anypoint access management - Roles
PDF
Angular material
PDF
هیبرید کارا، از رویا تا واقعیت!
PDF
Angular components
PPTX
Angular%201%20to%20angular%202
PDF
Beyond AngularJS: Best practices and more
PPTX
Angular js
PDF
How to easily design and automate test cases.pdf
PPTX
Lecture 32
PPT
Struts Introduction Course
PPTX
Web API with ASP.NET MVC by Software development company in india
PPTX
Intoduction to Angularjs
Introduction to Vaadin
Firebase. Предмет и область применения — Тимур Ахметгареев
Introduction To Angular 4 - J2I
Angular material tutorial
OAuth Authorization flows in salesforce
Anypoint access management - Roles
Angular material
هیبرید کارا، از رویا تا واقعیت!
Angular components
Angular%201%20to%20angular%202
Beyond AngularJS: Best practices and more
Angular js
How to easily design and automate test cases.pdf
Lecture 32
Struts Introduction Course
Web API with ASP.NET MVC by Software development company in india
Intoduction to Angularjs
Ad

Recently uploaded (20)

PDF
Adobe Illustrator 28.6 Crack My Vision of Vector Design
PPTX
ai tools demonstartion for schools and inter college
PDF
Why TechBuilder is the Future of Pickup and Delivery App Development (1).pdf
PDF
Nekopoi APK 2025 free lastest update
PPTX
VVF-Customer-Presentation2025-Ver1.9.pptx
PDF
System and Network Administration Chapter 2
PDF
PTS Company Brochure 2025 (1).pdf.......
PDF
Softaken Excel to vCard Converter Software.pdf
PDF
Understanding Forklifts - TECH EHS Solution
PDF
Odoo Companies in India – Driving Business Transformation.pdf
PDF
System and Network Administraation Chapter 3
PDF
Addressing The Cult of Project Management Tools-Why Disconnected Work is Hold...
PDF
How Creative Agencies Leverage Project Management Software.pdf
PDF
Wondershare Filmora 15 Crack With Activation Key [2025
PPTX
Odoo POS Development Services by CandidRoot Solutions
PDF
wealthsignaloriginal-com-DS-text-... (1).pdf
PDF
Flood Susceptibility Mapping Using Image-Based 2D-CNN Deep Learnin. Overview ...
PDF
top salesforce developer skills in 2025.pdf
PDF
Raksha Bandhan Grocery Pricing Trends in India 2025.pdf
PDF
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
Adobe Illustrator 28.6 Crack My Vision of Vector Design
ai tools demonstartion for schools and inter college
Why TechBuilder is the Future of Pickup and Delivery App Development (1).pdf
Nekopoi APK 2025 free lastest update
VVF-Customer-Presentation2025-Ver1.9.pptx
System and Network Administration Chapter 2
PTS Company Brochure 2025 (1).pdf.......
Softaken Excel to vCard Converter Software.pdf
Understanding Forklifts - TECH EHS Solution
Odoo Companies in India – Driving Business Transformation.pdf
System and Network Administraation Chapter 3
Addressing The Cult of Project Management Tools-Why Disconnected Work is Hold...
How Creative Agencies Leverage Project Management Software.pdf
Wondershare Filmora 15 Crack With Activation Key [2025
Odoo POS Development Services by CandidRoot Solutions
wealthsignaloriginal-com-DS-text-... (1).pdf
Flood Susceptibility Mapping Using Image-Based 2D-CNN Deep Learnin. Overview ...
top salesforce developer skills in 2025.pdf
Raksha Bandhan Grocery Pricing Trends in India 2025.pdf
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
Ad

Angular Dependency Injection