发生的情况是在第一次加载网站时,获取和缓存不会遇到任何问题。但是,在刷新(正常重新加载)时,Fetch 事件会遇到问题并在控制台日志中显示。
未捕获(承诺中)类型错误:self.addEventListener.e.respondWith.fetch.then.caches.open.then.cache 不支持请求方案“数据”
我意识到在重新加载时它会获取format data:[<mediatype>][;base64],<data>
导致控制台日志中错误的 a 。
// Call Fetch Event
self.addEventListener('fetch', e => {
console.log('Service Worker: Fetching');
e.respondWith(
fetch(e.request)
.then(res => {
// Make copy/clone of response
const resClone = res.clone();
// Open cahce
caches.open(cacheName).then(cache => {
// Add response to cache
cache.put(e.request, resClone);
});
return res;
})
.catch(err => caches.match(e.request).then(res => res))
);
});
我想避免这个错误,但我不知道如何。