サービスワーカーに問題があります。私はキャッシュからネットワーク技術を実装しました。ここでは、コンテンツがキャッシュから最初にフェッチされ、ネットワークフェッチが常に実行され、結果はキャッシュに入れられます。 (この解決策に触発されて、CSS-Tricks)サービスワーカー、ダブルキャッシング?
私は自分のWebアプリケーションを変更し、リフレッシュすると、私はもちろん、古いコンテンツを取得します。しかし、それ以降のリフレッシュでは、コンテンツは古いものと新しいものとの間で交互に表示されます。新しいコンテンツや古いコンテンツを5回連続して取得することも、リクエストごとに異なるコンテンツを作成することもできます。
サービスワーカーをしばらくデバッグしていて、賢明なことはありません。実装に何が間違っているのか誰かが考えていますか?
EDIT:
var version = 'v1::2';
self.addEventListener("install", function (event) {
event.waitUntil(
caches
.open(version + 'fundamentals')
.then(function (cache) {
return cache.addAll([
"/"
]);
})
);
});
self.addEventListener("fetch", function (event) {
if (event.request.method !== 'GET') {
return;
}
event.respondWith(
caches
.match(event.request)
.then(function (cached) {
var networked = fetch(event.request)
.then(fetchedFromNetwork, unableToResolve)
.catch(unableToResolve);
return cached || networked;
function fetchedFromNetwork(response) {
var cacheCopy = response.clone();
caches
.open(version + 'pages')
.then(function add(cache) {
cache.put(event.request, cacheCopy);
});
return response;
}
function unableToResolve() {
return new Response('<h1>Service Unavailable</h1>', {
status: 503,
statusText: 'Service Unavailable',
headers: new Headers({
'Content-Type': 'text/html'
})
});
}
})
);
});
self.addEventListener("activate", function (event) {
event.waitUntil(
caches
.keys()
.then(function (keys) {
return Promise.all(
keys
.filter(function (key) {
return !key.startsWith(version);
})
.map(function (key) {
return caches.delete(key);
})
);
})
);
});
私は、何が起こっているのかを正確に把握するために、もう少し掘り下げを行う必要があると思います。シークレットウィンドウまたはプライベートブラウジングモードでこの動作を再現できますか?デバッギングツールを使用して、サービスワーカーにリクエストを送信することができますか? – mjs
ネットワークコードが完了していないのにキャッシュが終了していない可能性はありますが、特定のコードを貼り付けて見てみましょう。 – Salva
コード – robbannn