Toggle property in parent Component from Child Component in Angular2 (similar to $emit in AngularJS)

后端 未结 2 556
半阙折子戏
半阙折子戏 2021-01-18 10:17

I\'m currently teaching myself Angular2 and I have a practical problem that would be easy to rectify in AngularJS but currently I\'m looking through examples to find a solut

2条回答
  •  北荒
    北荒 (楼主)
    2021-01-18 10:54

    I could leverage a shared service that define an EventEmitter property. Your App component will subscribe on it to be notified when the corresponding event is trigger by the TopNavigation component.

    • Shared service

      @Injectable()
      export class MenuService {
        showMenuEvent: EventEmitter = new EventEmitter();
      }
      

      Don't forget to define the corresponding provider in the boostrap function to be able to share the same instance of the service for the whole application: `bootstrap(App, [ MenuService ]);

    • App component

      @Component({ ... })
      export class App {
        showMenu: boolean = false;
        constructor(menuService: MenuService) {
          menuService.showMenuEvent.subscribe(
            (showMenu) => {
              this.showMenu = !this.showMenu;
            }
         );
       }
      

      }

    • TopNavigation component:

      export class TopNavigation {
        constructor(private menuService: MenuService) {
          // Things happening here
        }
      
        toggleMenu():void {
          this.showMenu = this.showMenu;
          this.menuService.showMenuEvent.emit(this.showMenu);
        }
      }
      

    See this question for more details:

    • Delegation: EventEmitter or Observable in Angular2

提交回复
热议问题