我是 PWA 新手并使用 Workbox;所以我有这个具有以下文件结构的测试文件夹,使用 localhost 作为我的服务器(即 localhost/test)
- 索引.html
- 测试.css
- 测试.jpg
- 测试.js
sw.js(代码如下所示);
importScripts(' https://storage.googleapis.com/workbox-cdn/releases/3.0.0/workbox-sw.js ');
if (workbox) { console.log(`Yay! Workbox is loaded `); } else { console.log(`Boo! Workbox didn't load `); } //precache all the site files workbox.precaching.precacheAndRoute([ { "url": "index.html", "revision": "8e0llff09b765727bf6ae49ccbe60" }, { "url": "test.css", "revision": "1fe106d7b2bedfd2dda77f06479fb676" }, { "url": "test.jpg", "revision": "1afdsoaigyusga6d9a07sd9gsa867dgs" }, { "url": "test.js", "revision": "8asdufosdf89ausdf8ausdfasdf98afd" } ]);
一切正常,文件已预先缓存,当我处于脱机模式时,我没有收到此常规脱机消息,如下图所示。
因此,我将确切的文件夹复制到 test-2 文件夹,然后将我的index.html 文件重命名为index.php并在我的sw.js 文件中将 url 更新为以下代码
{
"url": "index.php",
"revision": "8e987fasd5727bf6ae49ccbe60"
},
- 请注意,我也更改了修订值
我这样做是因为我想将使用 Workbox 的 PWA 实现到我自己定制的单页应用程序中(但它是 .php 格式的)。
来到我的浏览器运行 localhost/test-2 (正常模式),我的文件也被预缓存,包括我的 index.php 文件(我的控制台中没有错误消息,服务工作者工作得很好);只有我在我的源选项卡中切换到(离线模式)并刷新我的浏览器来测试离线体验,唉!我收到了这条离线消息,如下图所示:(
我不知道出了什么问题,我不知道发生了什么,我试图用谷歌搜索几天的一些原因,但我似乎没有得到任何正确和相应的答案。大多数教程都带有.html
所以问题是我如何使用 .php 文件实现 PWA,这样当用户离线时,他们不会收到正常的 You're offline Message 而是我的网页应该呈现?
提前致谢