Angular 2 - Dependency Injection

Wstrzykiwanie zależności to możliwość dodawania funkcjonalności komponentów w czasie wykonywania. Rzućmy okiem na przykład i kroki użyte do zaimplementowania iniekcji zależności.

Step 1- Utwórz osobną klasę z dekoratorem do wstrzykiwania. Dekorator do wstrzykiwania umożliwia wstrzykiwanie funkcjonalności tej klasy i używanie ich w dowolnym module Angular JS.

@Injectable() 
   export class classname {  
}

Step 2 - Następnie w swoim module appComponent lub module, w którym chcesz korzystać z usługi, musisz zdefiniować go jako dostawcę w dekoratorze @Component.

@Component ({  
   providers : [classname] 
})

Spójrzmy na przykład, jak to osiągnąć.

Step 1 - Utwórz plik ts plik dla usługi o nazwie app.service.ts.

Step 2 - Umieść poniższy kod w utworzonym powyżej pliku.

import { 
   Injectable 
} from '@angular/core'; 

@Injectable() 
export class appService {  
   getApp(): string { 
      return "Hello world"; 
   } 
}

Na temat powyższego programu należy zwrócić uwagę na następujące punkty.

  • Dekorator iniekcyjny jest importowany z modułu kątowego / rdzenia.

  • Tworzymy klasę o nazwie appService, która jest ozdobiona dekoratorem do wstrzykiwań.

  • Tworzymy prostą funkcję o nazwie getApp, która zwraca prosty ciąg znaków o nazwie „Hello world”.

Step 3 - W pliku app.component.ts umieść następujący kod.

import { 
   Component 
} from '@angular/core';  

import { 
   appService 
} from './app.service';  

@Component({ 
   selector: 'my-app', 
   template: '<div>{{value}}</div>', 
   providers: [appService]  
}) 

export class AppComponent { 
   value: string = ""; 
   constructor(private _appService: appService) { } 
   ngOnInit(): void { 
      this.value = this._appService.getApp(); 
   }   
}

Na temat powyższego programu należy zwrócić uwagę na następujące punkty.

  • Najpierw importujemy nasz moduł appService do modułu appComponent.

  • Następnie rejestrujemy usługę jako dostawca w tym module.

  • W konstruktorze definiujemy zmienną o nazwie _appService typu appService, dzięki czemu można ją wywołać w dowolnym miejscu modułu appComponent.

  • Na przykład w lifecyclehook ngOnInit wywołaliśmy funkcję getApp usługi i przypisaliśmy dane wyjściowe do właściwości value klasy AppComponent.

Zapisz wszystkie zmiany kodu i odśwież przeglądarkę, otrzymasz następujące dane wyjściowe.