使用beforeunload事件的脱机Web应用程序

时间:2018-04-13 11:41:32

标签: javascript web-applications offline service-worker

简单地说,当浏览器处于离线状态时,我正试图为我的网络应用程序创建简单的功能。该功能是一条简单的消息,告诉用户没有网络连接,而不是默认的浏览器页面。我尝试过以下方法:

window.addEventListener("beforeunload", function() {
                if (!navigator.onLine){
                    document.write("There is no network connection."); debugger;return false; 
                }                 
                }, false);

以上代码适用于Chrome,但它不适用于Firefox。我在这里有两个问题:

  1. 我怎样才能制作这种跨浏览器?
  2. 除了使用debugger之外还有其他方法吗?
  3.   

    更新

         

    这个问题的答案应该是

    的实现

1 个答案:

答案 0 :(得分:0)

最后,我找到了如何为我的网站实现简单的服务工作者。最终结果显示在以下屏幕截图中:

enter image description here

将客户端的计算机与网络断开连接后,(不使用浏览器的开发工具离线)并执行以下步骤,每个网站的页面都会加载offline.html

  1. 我使用了一个生成所需服务代码的在线工具PWA Builder,我逃过了第一步,生成清单,我直接从第2步开始,构建服务工作者。我从那里复制了网站代码,但是我修改了一些指向服务器根目录的路径,因为代码将被粘贴到应用程序布局中,如下所示:

         //在布局HTML的最顶部         //这是“离线页面”服务工作者

    //Add this below content to your HTML page, or add the js file to your page at the very top to register sercie worker
    if (navigator.serviceWorker.controller) {
      console.log('[PWA Builder] active service worker found, no need to register')
    } else {
      //Register the ServiceWorker
      navigator.serviceWorker.register('/pwabuilder-sw.js', { //notice slash in /pwabuilder-sw.js
        scope: './'
      }).then(function(reg) {
        console.log('Service worker has been registered for scope:'+ reg.scope);
      });
    }
    
    
    </script>
    

    2-我复制了服务工作者代码的代码,并将其作为/public保存在我的应用程序pwabuilder-sw.js的Web根目录中,同时更改了一些路径斜线:

    //这是“离线页面”服务工作者

    //Install stage sets up the offline page in the cahche and opens a new cache
    self.addEventListener('install', function(event) {
      var offlinePage = new Request('/offline.html'); //notice /
      event.waitUntil(
      fetch(offlinePage).then(function(response) {
        return caches.open('pwabuilder-offline').then(function(cache) {
          console.log('[PWA Builder] Cached offline page during Install'+ response.url);
          return cache.put(offlinePage, response);
        });
      }));
    });
    
    //If any fetch fails, it will show the offline page.
    //Maybe this should be limited to HTML documents?
    self.addEventListener('fetch', function(event) {
      event.respondWith(
        fetch(event.request).catch(function(error) {
            console.error( '[PWA Builder] Network request Failed. Serving offline page ' + error );
            return caches.open('pwabuilder-offline').then(function(cache) {
              return cache.match('/offline.html'); //notice /
          });
        }));
    });
    
    //This is a event that can be fired from your page to tell the SW to update the offline page
    self.addEventListener('refreshOffline', function(response) {
      return caches.open('pwabuilder-offline').then(function(cache) {
        console.log('[PWA Builder] Offline page updated from refreshOffline event: '+ response.url);
        return cache.put(offlinePage, response);
      });
    });
    
  2. 最后,我使用以下代码创建了public/offline.html文件:

    <html>
     <head>
     <meta name="viewport" content="width=device-width, initial-scale=1">
      <title>OffLine</title>
      <style>
       body{
        text-align: center;
        padding: 1em;
        font-family: sans-serif;
        font-size: 30px;
        }
      </style>
     </head>
     <body>
      <img src="" alt="Disconnected" />
      <h1>OffLine</h1>
      <p>There is no network connectivity.</p>
      <a href="javascript:location.reload()">Click here<a/> to reload after connecting.
     </body>
    </html>
    

    注意

    为了获得更好的测试结果,您可以使用以下提示:

    1. 清除浏览器的缓存并重新启动它。
    2. 物理断开机器,例如:关闭WiFi,当然第一次加载网站后!
    3. 另外

      我使用jQuery在整个应用程序中维护一些ajax请求,所以在布局脚本部分,我使用以下代码片段在发送之前检测每个ajax请求并检查浏览器是否脱机,因此它停止了ajax请求并提醒消息,然后重新加载页面以加载offline.html

      $( document ).ajaxSend(function(evt) {
          if (!navigator.onLine){
              evt.preventDefault();
              swal({
                  title: '{{__('OffLine Error')}}',
                  text: '{{__('The browser is offline. Some requests could not be done')}}',
                  confirmButtonText: '<i class="fox-finalize"></i>{{__('OK')}}',
                  onClose: function(){
                      location.reload();
                  }
              })
          }
        });