MDN’s new design is in Beta! A sneak peek: https://blog.mozilla.org/opendesign/mdns-new-design-beta/

Cache.addAll()

Diese Übersetzung ist unvollständig. Bitte helfen Sie, diesen Artikel aus dem Englischen zu übersetzen.

Dies ist eine experimentelle Technologie
Da diese Technologie noch nicht definitiv implementiert wurde, sollte die Browser Kompatibilität beachtet werden. Es ist auch möglich, dass der Syntax in einer späteren Spezifikation noch geändert wird.

Zusammenfassung

Die addAll() Methode der Cache Schnittstelle nimmt ein Array von URLS,  ruft diese ab und fügt die daraus resultierenden Antwortobjekte zum jeweiligen Cache hinzu. Die Antwortobjekte, welche während des Abrufens erzeugt werden, werden zu Schlüsselwerten für die gespeicherten Antwortoperationen. 

HinweisaddAll() überschreibt jegliche Schlüsselwertpaare im Cache, die der Anfrage entsprechen wird aber scheitern, wenn eine resultierende put() Operation einen früheren Cache-Eintrag, der durch die gleiche addAll() Methode erzeugt wurde, überschreiben würde.

Hinweis: Ursprüngliche Cache Implementationen (sowohl in Blink als auch in Gecko) lösen Cache.add, Cache.addAll, und Cache.put  Promises auf, wenn die jeweilige Antwort vollständig in den Speicher geschrieben wurde. Neuere Spezifikationsversionen haben aktualisierte Informationen, welche aussagen, dass der Browser den Promise bereits auflösen kann, wenn der Eintrag in die Datenbank erfolgt, auch wenn die Antwort  zu diesem Zeitpunkt noch nicht vollständig geschrieben wurde (sprich der Datenstrom in den Speicher ist noch nicht beendet).

Hinweis:  Zum Stand von Chrome 46 wird die Cache API nur Anfragen von sicheren Quellen speichern, also solche die via HTTPS angeboten werden.

Syntax

cache.addAll(requests[]).then(function() {
  //Anfragen wurden zum Cache hinzugefügt
});

Argumente

requests
Ein Array von Request Objekten, die Sie zum Cache hinzufügen möchten.

Rückgabewert

Ein Promise der mit void auflöst.

Ausnahmen

Ausnahme Passiert bei
TypeError

Das URL Schama ist nicht http oder https.

Der Antwortstatus ist nicht im 200er Bereich ( nicht erfolgreiche Antwort ). Dies entsteht, wenn die Anfrage nicht erfolreich zurückgibt, aber auch, wenn die Anfrage eine cross-origin no-cors Anfrage ist (in diesem Fall wird immer 0 als Berichtsstatus gegeben).

Beispiele

Dieser Programmblock wartet auf ein abgesetztes InstallEvent , woraufhin ein waitUntil läuft, das den Installationsprozess für die Applikation handhabt. Das beinhaltet das Aufrufen von CacheStorage.open um einen neuen Cache zu erstellen. Anschließend wird addAll() benutzt um diesem eine Reihe von Ressourcen (in diesem Fall html, css und Bild-Ressourcen) hinzuzufügen.

this.addEventListener('install', function(event) {
  event.waitUntil(
    caches.open('v1').then(function(cache) {
      return cache.addAll([
        '/sw-test/',
        '/sw-test/index.html',
        '/sw-test/style.css',
        '/sw-test/app.js',
        '/sw-test/image-list.js',
        '/sw-test/star-wars-logo.jpg',
        '/sw-test/gallery/',
        '/sw-test/gallery/bountyHunters.jpg',
        '/sw-test/gallery/myLittleVader.jpg',
        '/sw-test/gallery/snowTroopers.jpg'
      ]);
    })
  );
});

Spezifikationen

Spezifikation Status Kommentar
Service Workers
Die Definition von 'Cache' in dieser Spezifikation.
Arbeitsentwurf Erste Definition.

Browserunterstützung

Feature Chrome Firefox (Gecko) Internet Explorer Opera Safari (WebKit)
Basic support 46.0 (Ja)[1] Nicht unterstützt 24 Nicht unterstützt
Require HTTPS 46.0 (Ja)[1] ? ? ?
TypeError if request is not successful (Ja) 47.0 (47.0)[1] (Ja) (Ja) (Ja)
Feature Android Android Webview Firefox Mobile (Gecko) Firefox OS IE Mobile Opera Mobile Safari Mobile Chrome for Android
Basic support Nicht unterstützt Nicht unterstützt (Ja) ? Nicht unterstützt ? Nicht unterstützt 46.0
Require HTTPS Nicht unterstützt Nicht unterstützt (Ja) ? ? ? ? 46.0
TypeError if request is not successful (Ja) (Ja) (Ja) (Ja) (Ja) (Ja) (Ja) (Ja)

[1] Service workers (und Push) wurden in Firefox 45 Extended Support Release (ESR.) abgeschaltet.

Siehe auch

Schlagwörter des Dokuments und Mitwirkende

 Mitwirkende an dieser Seite: ChrisEbner
 Zuletzt aktualisiert von: ChrisEbner,