Angular 6订阅构造函数上的事件多次调用

Posted

技术标签:

【中文标题】Angular 6订阅构造函数上的事件多次调用【英文标题】:Angular 6 subscribe Event on constructor called multiple times 【发布时间】:2019-04-21 11:04:15 【问题描述】:

在我的构造函数组件(子组件)中添加简单事件

这是我的代码:

   this._modalService.onHidden.subscribe(
      result => 
        console.log("_modalService.onHidden");
        if(this.shown)
          this.shown = false;
          this._router.navigate(['.'],  relativeTo: this._route.parent );
        
      , error => console.log(error));

在第一次打开此页面时,此事件仅调用了一个 但是当再次进入页面时,这个事件调用了两次 当输入 3 次时,此事件称为 3 次等。

[顺便说一句,如果我在 ngOnInit 事件上移动代码,也会发生这种情况 这也发生在该事件多次调用的另一个事件 ngrx 存储管道上 ]

这是我的路线(也许是这个原因)

const routes: Routes = [
  
    path:':id' ,component:EventComponent,
    children:[
      
      path:'o/:file'
      ,component:EventDetailComponent
    ]
  ,
  
    path:':id/:sub' ,component:EventComponent,
    children:[
      path:'o/:file'
      ,component:EventDetailComponent
    ]
  
];

【问题讨论】:

【参考方案1】:

你应该取消订阅OnDestroy...

在构造函数中:

this.mySubscription = this._modalService.onHidden.subscribe(...);

onDestroy:

this.mySubscription.unsubscribe();

【讨论】:

以上是关于Angular 6订阅构造函数上的事件多次调用的主要内容,如果未能解决你的问题,请参考以下文章

Angular 2 - 构造函数调用后的生命周期事件

如何使用构造函数上的异步调用注入服务,Angular 2

在 angular2 中的 ngOnInit 之后,在构造函数中订阅服务

Angular 组件构造函数被调用两次

在哪里订阅 Angular 中的 observable、构造函数或 ngoninit [关闭]

NgrxStore 和 Angular - 大量使用异步管道或在构造函数中只订阅一次