admin管理员组

文章数量:1245117

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$;
}

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$;
}
Share Improve this question edited Jun 7, 2017 at 12:12 Olaf Horstmann 16.9k6 gold badges60 silver badges65 bronze badges asked Jun 7, 2017 at 12:00 undefinedundefined 6,87413 gold badges53 silver badges101 bronze badges
Add a ment  | 

1 Answer 1

Reset to default 18

publishLast shares (as the name suggests) the last emitted value - which can only be determined when the stream pletes.

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 plete 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 plete immediately after the emission of this value.

本文标签: javascriptRxJS publishReplay vs publishLastStack Overflow