zoukankan      html  css  js  c++  java
  • [PWA] Show an Error when a POST or DELETE Fails in an Offline PWA

    We're storing JSON data in the cache - but that only applies to HTTP GET requests - and not to POST or DELETE requests.

    We'll add a fetch event listener to the service worker, where we can intercept all fetch requests in our app. We'll forward them to the server - but if they fail, then we'll return an error back to the app.

    In the app, we can detect that error, and respond by showing an alert that the functionality isn't available in offline mode.

    console.log("IN sw.js")
    
    workbox.skipWaiting();
    workbox.clientsClaim();
    
    workbox.routing.registerRoute(
        new RegExp('https:.*min.(css|js)'),
        workbox.strategies.staleWhileRevalidate({
            cacheName: 'cdn-cache'
        })
      )
    
      workbox.routing.registerRoute(
        new RegExp('(http|https|localhost)://.*:4567.*.json'),
        workbox.strategies.networkFirst()
      )
    
     // Handle the POST and DELETE requests by SW
      self.addEventListener('fetch', event => {
        if (event.request.method === "POST" || event.request.method === "DELETE") {
          event.respondWith (
            fetch(event.request).catch(err => {
              return new Response(
                JSON.stringify({error: "This action disabled while app is offline"}),
                {headers: {
                  'Content-Type': 'application/json'
                }}
              )
            })
          )
        }
      })
    
    workbox.precaching.precacheAndRoute(self.__precacheManifest || [])
  • 相关阅读:
    linux命令---常用组合
    linux---进程相关的命令
    linux命令---系统监控
    linux命令---find
    linux命令---sort
    linux命令---tar
    linux命令---split
    linux命令---awk进阶
    log4net使用方法
    URL编码:不同的操作系统、不同的浏览器、不同的网页字符集,将导致完全不同的编码结果。
  • 原文地址:https://www.cnblogs.com/Answer1215/p/10199432.html
Copyright © 2011-2022 走看看