子组件调用父组件方法_Angular 父组件与子组件通讯之共享服务

694e0024523a1d97ce6f2cb20410fad8.png
父组件和它的子组件共享同一个服务,利用该服务在组件家族内部实现双向通讯。该服务实例的作用域被限制在父组件和其子组件内。这个组件子树之外的组件将无法访问该服务或者与它们通讯。
Angular 父组件与子组件通讯之共享服务​www.deathghost.cn
8f2671a01103833e5c2db0222aa0c1dc.png

Angular有多种组件间传值通讯方法,今天在这里引用官方笔记下通过服务进行父子组件之间的通讯。具体根据项目内容归属对其划分。

前提是在哪个模块使用就在哪里引入,如果是全局性的,直接导入在项目的根模块即可,其下的组件均可访问该服务或通讯。

6c52090f9d15b346139d4f55d2d3ae73.png

使用场景:非同一个模块结构布局中某一路由下的页面在某种情况下需要向外发送命令,让其收到命令进行执行的情况下我们可以在根模块下创建一个服务,让其子组件均可访问。

好比父组件含有导航列表,我们在子组件中管理功能导航保存完毕后通知父组件导航更新一般,发送指定标识,其接收到对其再次请求。

首先在根模块下创建一个服务。

Import { Injectable, EventEmitter } From '@Angular/Core';
@Injectable({
  ProvidedIn: 'Root'
})
Export Class EventEmitterService {
  Public EventEmit =  New EventEmitter();
  Constructor() {}
}

第二步在根模块将其导入。(E.G:app.Module)

Import { EventEmitterService } From './Service/Event-Emitter.Service';
...
// 将其共享给子组件
Providers: [...Srevice]
...

最后子组件通过构造函数将其注入进来。

Import { EventEmitterService } From './Service/Event-Emitter.Service';
...
Constructor(Private EmitService: EventEmitterService){}
...

使用方法:

发送:

// 例如
This.EmitService.EventEmit.Emit({IsClosed: True, Params: 0});

接收:

Import { Subscription } From 'Rxjs';
...
GetVal = '';
Subscription: Subscription;
... 
This.Subscription = This.EmitS.EventEmit.Subscribe(Data => {
  If (Data['IsClosed']) {
   This.GetVal = Data['Params'];
  }
});

另外,自己订阅在组件被销毁时需要调用Unsubscribe()退订,防止内存泄漏。不然你会看到意想不到的效果,即使您导航到另一个组件视图里,也会一直有效,直到取消订阅为止。

所以,还需要再接收一方的组件NgOnDestroy钩子里执行退订

//   退订
This.Subscription.Unsubscribe();

如同 上篇文章"Angular 路由快照"场景下,如果使用到此方法通讯,不退订就会出现这种情况。具体细节根据实际项目而定,仅供阅读参考。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值