【发布时间】:2019-09-07 14:33:14
【问题描述】:
我正在创建一个需要离线支持和更新的网络应用。当我更新应用程序时,新的服务工作者开始从磁盘缓存缓存文件并且不更新应用程序。这会导致新缓存获取旧文件。 Screenshot of chrome network debbuging。
const STATICCACHE = 'v9';
const DYNCACHE = 'dv2';
//v9
const assets = [
// All my assets
];
// install
self.addEventListener('install', event => {
event.waitUntil(
caches.open(STATICCACHE).then(cache => {
console.log("caching assets");
cache.addAll(assets);
})
);
});
// activate event
self.addEventListener('activate', event => {
event.waitUntil(
caches.keys().then(keys => {
return Promise.all(keys
.filter(key => key !== STATICCACHE && key !== DYNCACHE)
.map(key => caches.delete(key))
)
})
)
});
//fetch event
self.addEventListener('fetch', event => {
if (event.request.url.indexOf('firestore.googleapis.com') === -1) {
event.respondWith(
caches.match(event.request).then(cacheRes => {
return cacheRes || fetch(event.request).then(fetchRes => {
return caches.open(DYNCACHE).then(cache => {
cache.put(event.request.url, fetchRes.clone());
return fetchRes;
})
});
})
);
}
});
它不适用于 chrome for android 和 safari 在 iOS 上。
感谢您的帮助
【问题讨论】:
标签: service-worker