From 0a9a93d8d88b6b25ce0d236c2e9e082eae014059 Mon Sep 17 00:00:00 2001
From: Ilya Grigorik TODO: define preload "response cache". Conceptually
- this should probably reuse [SW's cache
- logic](https://slightlyoff.github.io/ServiceWorker/spec/service_worker/#cache-objects)?
- In effect, the preload cache is a UA maintained response cache with a
- few interesting lifetime + eviction quirks. In addition to the HTTP cache, all browser implementations
+ provide one or more levels of additional caches, which sometimes
+ live before the HTTP cache (e.g. HTTP/2 server push responses are
+ typically not commited to HTTP cache until a client request is
+ made), and after the HTTP cache (e.g. in-process memory caches).
+ These caches are not defined today and need to be defined in Fetch
+ API— see [related
+ discussion](https://github.com/whatwg/fetch/issues/354). Conceptually, a preloaded response ought to be committed to the
+ HTTP cache, as it is initiated by the client, and also be available
+ in the memory cache and be re-usable at least once within the
+ lifetime of a fetch group. The user agent MUST NOT automatically execute or apply the resource
- against the current page context, and the user agent MUST retain the
- fetched response until it is matched with another request, or is no
- longer valid. To match a preloaded response, the user agent must run the
- following steps: TODO: define matching, see this bug
- and
- chromium discussion. This should probably live in Fetch? I.e.
- fetch requests should check this cache before checking browsers HTTP
- cache and going to network.Processing
-
+ against the current page context.
For example, if a JavaScript resource is fetched via a preload link and the response contains a `no-cache` directive, the fetched response is retained by the user agent and is made immediately @@ -356,11 +348,10 @@
HTTP/2 ([[!RFC7540]]) allows a server to pre-emptively send ("push") responses to the client. A pushed response is semantically equivalent to a server responding to a request and, similar to a preloaded response, is - retained by the user agent and executed by the application when - matched with another request - initiated by the application. As such, from an application perspective, - there is no difference between consuming a preload or a server push - response.
+ retained by the user agent and executed by the application when matched + with a request initiated by the application. As such, from an application + perspective, there is no difference between consuming a preload or a + server push response.The server MAY initiate server push for preload link resources defined by the application for which it is [authoritative][]. Initiating server push eliminates the request roundtrip between client and server @@ -411,7 +402,8 @@
+<link rel="preload" href="/assets/font.woff2" as="font" type="font/woff2"> <link rel="preload" href="/style/other.css" as="style"> <link rel="preload" href="//example.com/resource">