Most of the popular Angular state management libraries like NgRx expose application state in a form of a stream of state objects. This is usually implemented with the help of RxJS Observables.
The state updates get pushed to the components which react by re-rendering their templates to display the most recent version of the application state.
There are multiple ways in which it is possible to consume this observable stream of state updates by the components, the two most popular being:
Using the
subscribe()
method and storing the state on the component instance,todos$.subscribe(todos => this.todos = todos)
...The | async pipe unwraps the state object directly in the componentβs template,
<li *ngFor=βlet todo of todos$ | asyncβ></li>
...
I have been thinking about this question and related trade-offs for quite some time now. I was mostly in favor of using subscribe() but couldnβt really point out exact reasons why.
Top comments (8)
I was thinking...if I wanted to do some operation in a component based on a boolean stream, I am forced to subscribe so that I can call the the operation when the right boolean value is received right?
I would have to go from:
to:
Is this a correct assumption?
You can also do
this.fooExists$ = this.store.pipe(select(foo), filter(foo => !!foo));
then you can alsothis.fooExists$.subscribe(operation)
. But why do you have to call something for every foo? Can't it be implemented usingngrx
@Effect()
?I only need it to happen once and only one component is listening for it... Sort of like this component telling a sibling component that it is ready to do something... So I thought an effect would be Overkill, plus I'm not calling a new Action, the operation happens internally to the listening component.
Would i need to manually unsubscribe in OnDestroy if I did it this way (not @Effect) as you have described?
Yes, whenever you do explicit
.subscribe()
call, you are automatically responsible to call.unsubscribe()
. Even better would be to use.pipe(takeUntil(onDestroy$))
which is declarative ;)awesome, thanks!
so then I would also need to do this, right?
CHeers!
I have been using subscribe in ngOnInit and creating a subscription manager to unsub in OnDestroy which was ok because of couldn't definitely find out which way was better, but then just before this article came out I learned that using the async pipe handled the unsub for me, and now one learned it's also more performant so now I'm trying to use that as much as possible these days. Thanks for this article! I'm excited about the growing presence of angular articles here on Dev.