I am implementing caching HTTP results in Angular application. From what I know both of the following code works, but I need to know if they are doing exactly the same thing, or I am missing something important?
publishLast
getPosts() {
if( !this.posts$ ) {
this.posts$ = this.http.get('api').publishLast().refCount();
return this.posts$;
}
return this.posts$;
}
publishReplay
getPosts() {
if( !this.posts$ ) {
this.posts$ = this.http.get('api').publishReplay(1).refCount();
return this.posts$;
}
return this.posts$;
}
publishLast
shares (as the name suggests) the last emitted value - which can only be determined when the stream completes.
publishReplay(1)
shares the latest emitted value, which is done after any emission.
In the case of this.http.get(...)
the behavior is the same, because the stream will complete after the result was received, thus the last and the latest value are the same thing.
You will have a different result though for streams that emit more than one value or that do not complete immediately after the emission of this value.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With