Attualmente sto insegnando a me stesso Angular2 e ho un problema pratico che sarebbe facile da correggere in AngularJS ma attualmente sto cercando tra gli esempi trovare una soluzione con Angular2. Ad ogni modo, ho un componente di livello superiore chiamato App
e all'interno di quel componente ho una proprietà che applica una classe css, ecco il mio HTML che viene usato come modello di componente - puoi vedere dove desidero applicare la classe css usando ngClass
. Il valore showMenu
è solo un valore booleano.
<div class="navigation" role="navigation">
<ul>
<li><a [routerLink]="['Home]">Home</a></li>
<li><a [routerLink]="['Mail']">Mail</a></li>
<li><a [routerLink]="['Friends']">Friends</a></li>
<li><a [routerLink]="['Games']">Games</a></li>
</ul>
</div>
<!-- below is where I wish to toggle the class -->
<div class="site-wrap" [ngClass]="{'slide-right': showMenu}">
<div class="container-fluid">
<div class="row nav">
<top-navigation></top-navigation>
</div>
</div>
<div class="container-fluid content-gradient">
<div class="row">
<div class="col-md-10">
<router-outlet></router-outlet>
</div>
<div class="col-md-2">
<contacts-list></contacts-list>
</div>
</div>
</div>
<div class="container-fluid footer">
<footer-navigation></footer-navigation>
</div>
</div>
Ecco il codice Componente per App (non tanto da vedere qui ...)
export class App {
showMenu: boolean = false;
constructor() {
}
// I need to listen for the toggle somehow?
toggleMenu():void {
this.showMenu = !this.showMenu;
}
}
ora si può vedere ho un componente figlio con il selettore top-navigation
. Questo componente TopNavigation
ha un metodo su un pulsante che desidero commutare il valore di showMenu
nel componente principale/principale. Ecco il mio codice finora (solo piccoli estratti)
export class TopNavigation {
constructor() {
// Things happening here
}
toggleMenu():void {
// I want to toggle the parent property by somekind of $emit
}
}
qui è il modello HTML (non tutti) per la componente.
<div class="col-xs-2 col-sm-1 hidden-md hidden-lg hamburger-menu">
<button class="btn btn-default" (click)="toggleMenu()">☰</button>
</div>
In AngularJS avrei un $scope.$emit
sulla funzione toggleMenu
e nel genitore avrei una $scope.$on
di ascoltare per l'evento. Attualmente sto leggendo su EventEmitters
in Angular2, ma se qualcuno ha una spiegazione/esempio rapido sarei molto riconoscente soprattutto perché penso che questo sia un compito quotidiano/pratico per gli sviluppatori angolari.
Se si dispone di un rapporto diretto tra genitori e figli, io preferisco la risposta di Günter. Se hai bisogno di cambiare il valore da più componenti, allora vai con la risposta di Theyry (ma usa un Observable piuttosto che un EventEmitter). –