Skip to content
This repository has been archived by the owner on Aug 3, 2023. It is now read-only.

Latest commit

 

History

History
72 lines (58 loc) · 1.97 KB

request-deduplication.md

File metadata and controls

72 lines (58 loc) · 1.97 KB

Request Deduplication

React Request will prevent two identical HTTP requests from being in flight at the same time. It does this by comparing the request key of any new request with the keys of all in-flight requests.

When an existing request is already in flight for that same key, then a new request will not be dispatched. Instead, the same response will be sent to both requestors.

Examples

In the following example, only one HTTP request is made:

class App extends Component {
  render() {
    return (
      <div>
        <Fetch url="/posts/1" />
        <Fetch url="/posts/1" />
      </div>
    );
  }
}

However, in this example, two requests are made because the URLs are different, resulting in a different request key:

class App extends Component {
  render() {
    return (
      <div>
        <Fetch url="/posts/1" />
        <Fetch url="/posts/2" />
      </div>
    );
  }
}

Reliability

The default request key implementation assumes that JSON.stringify will produce the same string given two different objects that would be considered "deeply equal" (for instance, if they were compared using _.isEqual).

This may seem unreliable to you, but Apollo has been doing it this way for some time, and that is a library with half a million downloads per month (as of February 2018). So it seems to be reliable.

Needless to say, if this behavior ever causes problems, then we will revisit the approach.

Disabling deduplication

You can disable deduplication with the dedupe prop.

// In this example, two identical HTTP requests will be made at the same time.
class App extends Component {
  render() {
    return (
      <div>
        <Fetch url="/posts/1" dedupe={false} />
        <Fetch url="/posts/1" dedupe={false} />
      </div>
    );
  }
}