angular2+ EventEmitter发送消息loadChildren下页面无法接收
路由:
{path: 'index', component: IndexComponent},
{path: 'aaa', loadChildren: './user/user.module#UserModule'},
EventEmitter:
this.emitService.eventEmit.emit({aaa: true});
this.emitService.eventEmit.subscribe(data => {
// index页面可以获取到
// aaa页面无法获取(loadChildren)
})
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
这些页面注入的emitService是同一个实例吗?如果不是同一个实例,自然收不到事件。虽然Angular的DI自称是默认单例,但其实不完全是这样,其实只是来自某个模块中注册provider的服务才是单例的,所以,你应该查一下,emitService是否在不同的模块中注册provider。
为了保证emitService单例,emitService应该只在一个模块中注册provider,通常是根模块。