Service worker sends two requests

后端 未结 1 2122
灰色年华
灰色年华 2021-01-19 03:25

I\'ve implemented a service worker which caches all requests for offline usage, this works fine. But everytime I load a page there are two requests hitting my webserver (one

1条回答
  •  逝去的感伤
    2021-01-19 04:26

    So here's what happens whenever you make a request:

    1. The webpage sends a fetch request to the server,
    2. the Service Worker intercepts the request on the 'fetch' event,
    3. pushToCache() fires a fetch request to the server in order to cache the response,
    4. then you respond to the event with a fetch request to the server which will return a Promise for a Response from the web server.

    Yup, that makes sense, that thing just sent two requests two the server for every request the page originally made.

    One thing you might want to consider is responding from the cache first and then going on the network to get the latest data. This way you will avoid delays in loading in the case of connection issues and it will speed up the loading time of the page even when the user is online.

    Let's consider the following scenario: Either the user or the server are offline. Once you fire the request, it will have to time out before it goes to the catch part of the promise and get the cached response.

    What you could do once you intercept the event is check the caches for a match and if you find anything, respond to the event with that. Then start a fetch request in order to update the cache. Now if you don't find anything, fire a fetch request, clone the response (because the response body can only be used once), respond with the original response and then update the cache with the cloned response.

    What did we achieve with that?

    The user gets an instant response, no matter if he's online, offline or on Lie-Fi!

    The server gets at most one request and the caches will always get updated with the latest data from the server!

    serviceworke.rs is a great resource that can help you understand how to do many interesting things with Service Workers.

    This page in particular explains in a bit more detail how what I said above works.

    0 讨论(0)
提交回复
热议问题