Angular - 当孙子函数执行时,触发祖父函数
创始人
2024-10-14 15:00:51
0

要实现当孙子函数执行时触发祖父函数的功能,可以使用事件订阅/发布模式(EventEmitter)来解决。下面是一个示例代码:

  1. 创建一个共享数据服务(SharedDataService),用于在祖父组件和孙子组件之间共享数据和事件。
import { Injectable, EventEmitter } from '@angular/core';

@Injectable()
export class SharedDataService {
  public grandparentEvent: EventEmitter = new EventEmitter();

  constructor() {}

  triggerGrandparentEvent(): void {
    this.grandparentEvent.emit();
  }
}
  1. 在祖父组件中,订阅共享数据服务中的grandparentEvent事件,并定义一个触发的函数。
import { Component } from '@angular/core';
import { SharedDataService } from 'shared-data.service';

@Component({
  selector: 'grandparent',
  template: `
    

Grandparent Component

`, providers: [SharedDataService] }) export class GrandparentComponent { constructor(private sharedDataService: SharedDataService) {} triggerGrandparentEvent(): void { this.sharedDataService.triggerGrandparentEvent(); } }
  1. 在父组件中,订阅共享数据服务中的grandparentEvent事件,并定义一个触发的函数。
import { Component } from '@angular/core';
import { SharedDataService } from 'shared-data.service';

@Component({
  selector: 'parent',
  template: `
    

Parent Component

`, providers: [SharedDataService] }) export class ParentComponent { constructor(private sharedDataService: SharedDataService) {} ngOnInit(): void { this.sharedDataService.grandparentEvent.subscribe(() => { this.triggerParentEvent(); }); } triggerParentEvent(): void { console.log('Parent event triggered'); } }
  1. 在孙子组件中,通过注入共享数据服务,并在需要执行时调用共享数据服务的triggerGrandparentEvent函数。
import { Component } from '@angular/core';
import { SharedDataService } from 'shared-data.service';

@Component({
  selector: 'child',
  template: `
    
Child Component
` }) export class ChildComponent { constructor(private sharedDataService: SharedDataService) {} triggerGrandparentEvent(): void { this.sharedDataService.triggerGrandparentEvent(); } }

在这个示例中,当点击祖父组件中的按钮或孙子组件中的按钮时,都会触发祖父组件的函数。

相关内容

热门资讯

最新通报!wepoker怎么设... 最新通报!wepoker怎么设置透视,德扑圈有透视吗,细节揭秘(有挂软件);实战中需综合运用上述技巧...
必看攻略!wpk辅助,wepo... 必看攻略!wpk辅助,wepoker辅助器下载,解说技巧(有挂辅助)是一款可以让一直输的玩家,快速成...
一分钟带你了解!aapoker... 一分钟带你了解!aapoker怎么拿好牌,aapoker辅助插件工具,线上教程(有挂透明)准备好在a...
我来分享!hhpoker可以控... 我来分享!hhpoker可以控制牌吗,德州局透视,辅助教程(有挂透视);大神普及一款德州ai内幕,确...
科技揭秘!约局吧app有挂吗,... 科技揭秘!约局吧app有挂吗,wepoker透视脚本网页,总结教程(有挂技巧);小薇(透视辅助)致您...
一起来讨论!hhpoker是正... 1、一起来讨论!hhpoker是正品吗,大菠萝免费辅助,wpk教程(有挂神器)。2、大菠萝免费辅助透...
推荐十款!aapoker发牌逻... 您好,佛手大菠萝有挂吗这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在...
玩家必看科普!wepoker买... 自定义wepoker买钻石有用吗系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅...
热点讨论!wepoker透视是... 热点讨论!wepoker透视是真的吗,wepoker手机版辅助,教你教程(有挂透视)1、点击下载安装...
我来教大家!wejoker黑侠... 我来教大家!wejoker黑侠辅助器,wepoker透视脚本免费使用视频,必赢方法(有挂透视);致您...