我有服务员。这是安装事件:
self.addEventListener('install', function (event) {
console.log('Installing Service Worker ...', event);
return self.skipWaiting()
.then(() => caches.open(CACHE_STATIC_NAME))
.then(function (cache) {
return cache.addAll([
'./file1.html',
'./file2.html'
])
})
});
出于某种原因,当我编辑服务 worker 代码并更新服务 worker 文件URL中的查询参数时,即使我将其称为
self.skipWaiting()
,它也会安装但不会激活(根据Chrome DevTools)。奇怪的是,如果我进入控制台,进入服务 worker 的范围,然后自己输入
self.skipWaiting()
,它将立即激活。我一直在努力弄清楚现在发生了什么事情,而我完全陷入了困境。这里有我想念的东西吗?
最佳答案
旧的SW可能在运行任务时可能不会停止运行-例如,如果它具有长时间运行的获取请求(例如服务器发送的事件/事件源或获取流;尽管我不认为Websocket会导致这种情况,因为SW会忽略它们)我认为)。
我发现浏览器之间的行为是不同的。 Chrome似乎在等待现有任务运行时等待(因此skipWaiting将失败...),但是Safari似乎取消了该任务并激活了新的软件。
测试这是否引起问题的一种好方法是在您请求skipWaiting之后立即终止服务器(终止网络连接)。 (仅在开发工具中单击“脱机”似乎并不会杀死所有正在运行的连接,例如EventSources仍在运行。)
您可以让SW忽略某些路由(如下),也可以尝试强制终止请求(也许使用AbortController)。
self.addEventListener('fetch', function(event) {
const { method, url } = event.request;
if(event.request.method !== "GET") return false;
if(url === "https://example.com/poll") return false;
event.respondWith(
caches.match(match).then(function(response) {
return response || fetch(event.request);
})
);
});
此规范中的skipWaiting流程为:
https://w3c.github.io/ServiceWorker/#try-activate-algorithm
但是我不清楚在激活新软件之前浏览器是否应该等待任务或终止它们(或将它们转移到新软件?)。并且如前所述,目前浏览器之间的工作方式似乎有所不同...
关于javascript - self.skipWaiting()在Service Worker中不起作用,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/54628657/