Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Subscription Code Firing off Incrementally Every Time Component Loads

In my component's ngOnInit I have the following:

public Subscription: Subscription;

ngOnInit() {
    this.subscription =  this.myService.currentData.subscribe( i => {
        this.currentData = i;
        this.function(this.currentData)
    });
}

When my component loads, I have it subscribe to some data in a service to later use in a function. Loading it the first time works great. However, when I load to another module then come back, the function will fire off two times. Every time I repeat this process the function will fire off and increment. Meaning if I switch in and out of the module say 5 times, the function will fire off 5 times.

My attempt at solving this was to add an unsubscribe to ngOnDestroy like so:

ngOnDestroy() {
    this.subscription.unsubscribe();
}

However this seems to do nothing as the issue still occurs.

like image 583
TheGreatZab Avatar asked Oct 24 '25 17:10

TheGreatZab


1 Answers

Two issues were present. First off, I was declaring my Subscription incorrectly.

Instead of this:

public Subscription: Subscription;

This is what needs to be put:

public Subscription = new Subscription();

Also, instead of equating my Subscription to my subscribe statement, I switched to .add(). This allows me to have my subscription object be assigned to all subscribers and unsubscribe them in one go:

this.Subscription.add(this.myService.currentData.subscribe( i => {
    this.currentData = i;
    this.function(this.currentData)
}));
like image 125
TheGreatZab Avatar answered Oct 26 '25 08:10

TheGreatZab



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!