Dependency Injection
Ziele
- Du weisst, was eine Dependency Injection ist und was es in Angular ist.
- Du kannst, eine Dependency Injection anwenden.
Was sind Dependencies (Abhängigkeiten)
Um eine loose Kopplung zu erreichen, werden verschiedene Aufgaben wie das Laden von Server-Daten in verschiedene Dateien ausgelagert. Die einzelnen Klassen haben Abhängigkeiten zu einander. In Angular gibt man die Abhängigkeiten zu anderen Klassen oft z.B. im Konstruktor an.
Angular erstellt und übergibt dann automatisch Instanzen dieser Klassen beim Laden der entsprechenden Klasse. Auf diese Weise werden die Klassen wiederverwendbarer und einfacher testbar.
Was ist eine Dependency Injection
Dependency Injection ist ein Coding pattern, bei welchem Klassen alle Abhängigkeiten von externen Quellen erhalten, anstatt sie selbst zu erstellen.
Dependency Injection in Angular
Der Angular Dependency Injector liefert uns Vorteile wie Skalierbarkeit, Testbarkeit und eine klare Trennung von Aufgaben.
Um den Dependency Injector in Angular zu nutzen, müssen wir 3 Schritte erledigen
- Den
@Injectable()
Decorator der Klasse/ dem Service hinzufügen. - Den Injector davon erzählen, indem wir es als Provider aufzählen.
- Die Dependency injecten
- @Injectable importieren und nutzen:
|
|
- Den WeaponService als Provider registrieren (in
module.ts
):
|
|
- Dependency injecten wo (in unserem Beispiel) der Service genutzt wird:
|
|
Das Minibeispiel soll lediglich die 3 wichtigen Schritte etwas besser darstellen.
Lernvideo
Wenn du dir die Erklärung noch mit einem Video genauer anschauen möchtest, empfiehlt dir das Praxisbildner-Team dieses Video.