title | slug |
---|---|
CacheStorage.match() |
Web/API/CacheStorage/match |
{{APIRef("Service Workers API")}}{{SeeCompatTable}}
La fonction match()
de l'interface {{domxref("CacheStorage")}} qu'une {{domxref("Request", "Requête")}} est la clé d'un objet {{domxref("Cache")}} object suivie par un objet {{domxref("CacheStorage")}} et retourne une {{jsxref("Promise", "Promesse")}} qui renvoie la {{domxref("Response", "Réponse")}} correspondante.
Vous pouvez accéder à CacheStorage
via la propriété globale caches
.
Les objets Cache
sont cherchés par ordre de création.
Note : {{domxref("CacheStorage.match()", "caches.match()")}} est une méthode de commodité. Une fonctionnalité équivalente consiste à appeler {{domxref("cache.match()")}} sur chaque cache (dans l'ordre renvoyé par {{domxref("CacheStorage.keys()", "caches.keys()")}}) jusqu'à ce qu'une {{domxref("Response", "Réponse")}} soit renvoyée.
caches.match(request, { options }).then(function (response) {
// faire quelque-chose avec la requête et la réponse
});
-
request
- : La {{domxref("Request", "Requête")}} recherchée.
-
options {{optional_inline}}
-
: Un objet dont les propriétés contrôlent comment la correspondance est fait avec l'opération
match
. Les options disponible sont:ignoreSearch
: Un {{domxref("Boolean")}} qui détermine si le preocessus de rapprochement doit ignorer la chaîne de requête dans l'url. Défini àtrue
, la partie?value=bar
dehttp://foo.com/?value=bar
sera ignoré lors d'un rapporchement. La valeur par défaut estfalse
.ignoreMethod
: Un {{domxref("Boolean")}} qui, quand défini àtrue
, empêche l'opération de rapprochement de valider le verbe http de la {{domxref("Request", "Requête")}}http
(normalement, seulementGET
etHEAD
sont authorisés) La valeur par défaut estfalse
.ignoreVary
: Un {{domxref("Boolean")}} qui, quand défini àtrue
, dit à l'opération de rapprochement de ne pas faire le rapprochement avec le headerVARY
. En d'autres termes, si une URL est sélectionnée elle sera conservée indépemment de la présence du headerVARY
. La valeur par défaut estfalse
.cacheName
: Un {{domxref("DOMString")}} qui représente le cache dans lequel on recherche.
-
Une {{jsxref("Promise", "Promesse")}} qui renvoie les {{domxref("Response", "Réponses")}} correspondante.
Cet exemple est tiré du MDN sw-test example (voir sw-test running live). Nous attendons pour un évènement {{domxref("FetchEvent")}} et nous construisons une réponse comme suit:
- Vérifier si une correspondance pour la requète est trouvée dans le {{domxref("CacheStorage")}} en utilisant {{domxref("CacheStorage.match")}}. Si oui, la servir.
- Si non, ouvrire le cache
v1
avecopen()
, mettre le réseau par défaut dans le cache avec {{domxref("Cache.put")}} et retourner un clone du réseau par défaut en utilisantreturn response.clone()
— obligatoire carput()
détruit le corps de la réponse. - Si ceci échoue (e.g., parce que le réseau est inactif), retourner une réponse de secours.
self.addEventListener("fetch", function (event) {
event.respondWith(
caches.match(event.request).then(function (response) {
// caches.match() always resolves
// but in case of success response will have value
if (response !== undefined) {
return response;
} else {
return fetch(event.request)
.then(function (response) {
// response may be used only once
// we need to save clone to put one copy in cache
// and serve second one
let responseClone = response.clone();
caches.open("v1").then(function (cache) {
cache.put(event.request, responseClone);
});
return response;
})
.catch(function () {
return caches.match("/sw-test/gallery/myLittleVader.jpg");
});
}
}),
);
});
{{Specifications}}
{{Compat}}
- Utiliser les Service Workers
- {{domxref("Cache")}}
caches