首页 > 后端开发 > Python教程 > PWA 和 Django #PWA 中的在线和离线资源 - 使用 Django 开发渐进式 Web 应用程序

PWA 和 Django #PWA 中的在线和离线资源 - 使用 Django 开发渐进式 Web 应用程序

DDD
发布: 2024-11-29 02:03:10
原创
541 人浏览过

注意:首次发布于:https://andresalvareziglesias.substack.com/p/pwa-and-django-3-online-and-offline

欢迎来到 Django 渐进式 Web 应用程序系列的第三篇文章。在本章中,我们将学习如何为 PWA 缓存资源,以便能够在没有有效互联网连接的情况下离线使用它们。

PWA and Django #Online and offline resources in a PWA - Developing Progressive Web Applications with Django

实施离线功能

在前面的章节中,我们定义了一个小型 PWA 应用程序,其中包含每个必需的部分:清单和 ServiceWorker。我们学习了如何注册 PWA 并使用一些图像开发了一个非常简单的界面:

PWA and Django #Online and offline resources in a PWA - Developing Progressive Web Applications with Django

现在我们将学习如何在 PWA 缓存中存储数据以及如何选择加载每个图像的位置:从互联网或本地缓存。

为了在 PWA 缓存上存储一个或多个资源,我们在 ServiceWorker 上使用如下函数:

const CACHE_NAME = "DJANGO_PWA_TEST"
const MAIN_URL = "https://laboratorio.alvarezperello.com/djangopwa/";

self.addEventListener("install", (event) => {
   console.info("*** PWA event *** install", event);
   event.waitUntil(activateApp());
});

self.addEventListener("activate", (event) => {
   console.info("*** PWA event *** activate", event);
   event.waitUntil(activateApp());
});

async function activateApp() {
   // When a service worker is initially registered, pages won't use it
   // until they next load. The claim() method causes those pages to be
   // controlled immediately.
   console.log('Claiming control...');
   clients.claim().then((ev) => {
       console.log('...claimed!', ev);
   })

   manageCache();
}

self.addEventListener("sync", (event) => {
   console.info("*** PWA event *** sync", event);
   manageCache();
});

async function manageCache() {
   const cache = await caches.open(CACHE_NAME);
   if (!cache) {
       console.error("Error storing resources in cache!");
       return;
   }

   storeResourceInCache(cache, MAIN_URL+"static/demo/img/snake1.jpg");
   //storeResourceInCache(cache, MAIN_URL+"static/demo/img/snake2.png");
   //storeResourceInCache(cache, MAIN_URL+"static/demo/img/snake3.png");
}

async function storeResourceInCache(cache, element) {
   console.log("Storing resource in cache: "+element);
   cache.add(element).then(event => {
       console.info("Resource stored successfully! "+element);
   }).catch(event => {
       console.error("Error storing resource! "+element, event);
   });
}
登录后复制

现在,当我们执行 PWA 时,我们可以在开发者控制台中读取缓存消息:

Registering service worker...
...register completed!
The service worker is active!

serviceworker.js: Claiming control...
serviceworker.js: Resource already in cache! static/demo/img/snake1.jpg
登录后复制

我们的 PWA 缓存正在运行!

选择从何处加载每个资源

当 PWA 加载资源时,调用 fetch 事件,如下所示:

self.addEventListener("fetch", async (event) => {
   console.info("*** PWA event *** fetch", event);

   let url = event.request.url.toString();
   console.info("The PWA is loading a resource from: "+url);
});
登录后复制

我们现在可以控制请求,并且可以选择从何处返回请求的资源:从缓存或从互联网。

这是一个如何检查我们是否缓存了资源并从缓存中返回它的示例。并且,如果未缓存,请改为从互联网请求。

self.addEventListener("fetch", async (event) => {
   let url = event.request.url.toString();
   if (!url.includes("static/demo/img/snake")) {
       return false;
   }

   const cache = await caches.open(CACHE_NAME);
   if (!cache) {
       console.error("Error loading resources from cache!");
       return false;
   }

   let fetchResponsePromise = await cache.match(url).then(async (cachedResponse) => {
       if (cachedResponse && cachedResponse.ok) {
           console.warn("Loading from cache: "+url);
           return cachedResponse;

       } else {
           console.error("Error! the cache does not have this url! "+url);
           console.error(cache.keys());

           remoteFetchResponsePromise = await fetch(event).then(async (networkResponse) => {
               console.warn("Loading from internet: "+url);
               return networkResponse;
           });

           return remoteFetchResponsePromise;
       }
   });

   return (await fetchResponsePromise);
});
登录后复制

我们可以读取开发者控制台来了解每个图像是从哪里加载的,如下所示:

PWA and Django #Online and offline resources in a PWA - Developing Progressive Web Applications with Django

在下一章中

我们现在有了 PWA。现在我们将学习如何制作可安装的 PWA,它将在操作系统中显示为本机应用程序。这是 PWA 最强大的功能之一:我们可以使用它们来使用 Django 创建“几乎本机”的应用程序。

下一章见!

关于名单

在 Python 和 Docker 帖子中,我还会写一些其他相关主题,例如:

  • 软件架构
  • 编程环境
  • Linux操作系统
  • 等等

如果您发现了一些有趣的技术、编程语言或其他什么,请告诉我!我总是乐于学习新东西!

关于作者

我是 Andrés,一位来自帕尔马的全栈软件开发人员,我正在踏上提高编码技能的个人旅程。我也是一位自行出版的奇幻作家,以我的名义出版了四本小说。有什么问题都可以问我!

以上是PWA 和 Django #PWA 中的在线和离线资源 - 使用 Django 开发渐进式 Web 应用程序的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板