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.