From 50ce47eaac5de09924ad7e3611f017d03afa6857 Mon Sep 17 00:00:00 2001 From: nonameShijian <2954700422@qq.com> Date: Wed, 7 Feb 2024 23:43:57 +0800 Subject: [PATCH] =?UTF-8?q?=E6=9B=B4=E6=96=B0http=E5=8D=8F=E8=AE=AE?= =?UTF-8?q?=E5=AE=8C=E6=88=90=E5=90=8E=E5=BB=B6=E8=BF=9F=E9=87=8D=E5=90=AF?= =?UTF-8?q?=EF=BC=8C=E5=88=9D=E6=AC=A1=E5=8A=A0=E8=BD=BDserviceWorker?= =?UTF-8?q?=E9=87=8D=E5=90=AF?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- game/entry.js | 4 +++- game/game.js | 30 ++++++++++++++++++++---------- 2 files changed, 23 insertions(+), 11 deletions(-) diff --git a/game/entry.js b/game/entry.js index beeeb229c..85e7f50a8 100644 --- a/game/entry.js +++ b/game/entry.js @@ -62,7 +62,9 @@ boot().then(() => { const thisWindow = remote.getCurrentWindow(); thisWindow.loadURL(url); } else { - location.href = url; + setTimeout(() => { + location.href = url; + }, 1000); } } } diff --git a/game/game.js b/game/game.js index 5dc94eeb4..0ecc5ebf3 100644 --- a/game/game.js +++ b/game/game.js @@ -136,17 +136,27 @@ new Promise(resolve => { } if (location.protocol.startsWith('http') && 'serviceWorker' in navigator) { let scope = window.location.protocol + '//' + window.location.host + '/'; - navigator.serviceWorker.register(`${scope}service-worker.js`, { - updateViaCache: "all", - scope, - }).then(registration => { - navigator.serviceWorker.addEventListener('message', e => { - console.log(e); + navigator.serviceWorker.getRegistrations().then(registrations => { + let findServiceWorker = false; + for (let registration of registrations) { + if (registration && registration.active && registration.active.scriptURL == `${scope}service-worker.js`) { + findServiceWorker = true; + } + } + navigator.serviceWorker.register(`${scope}service-worker.js`, { + updateViaCache: "all", + scope, + }).then(registration => { + // 初次加载worker,需要重新启动一次 + if (!findServiceWorker) location.reload(); + navigator.serviceWorker.addEventListener('message', e => { + console.log(e); + }); + registration.update(); + // console.log(`set scope: ${scope}, service worker instance:`, registration); + }).catch(e => { + console.log('serviceWorker加载失败: ', e); }); - registration.update(); - // console.log(`set scope: ${scope}, service worker instance:`, registration); - }).catch(e => { - console.log('serviceWorker加载失败: ', e); }); } const script = document.createElement('script')