繁体   English   中英

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

[英]Offline web application using beforeunload event

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

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

上面的代码适用于Chrome,但不适用于firefox。 我在这里有两个问题:

  1. 我怎样才能使这个跨浏览器?
  2. 除了使用debugger还有其他方法吗?

更新资料

这个问题的答案应该是的实现

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

在此处输入图片说明

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

  1. 我使用了一个在线工具来生成所需的服务代码PWA Builder ,我从此处的第一步“ Generate Manifest”中退出了 ,我直接从步骤2 Build Service Worker开始。 我从那里复制了网站代码,但是我修改了一些路径以指向服务器的根目录,因为代码将被粘贴到应用程序布局中,如下所示:

    //在布局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的Web根目录下的新文件中,名为pwabuilder-sw.js ,并用斜杠更改了一些路径:

    //这是“离线页面”服务人员

     //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); }); }); 

最后,我使用以下代码创建了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,当然是第一次加载网站后!

另外

我使用jQuery在整个应用程序中维护一些ajax请求,因此在布局脚本部分中,我使用了以下代码段,该代码段在发送每个ajax请求之前都会对其进行检测,并检查浏览器是否处于脱机状态,因此它会停止ajax请求并提醒a消息,然后重新加载页面以加载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();
            }
        })
    }
  });  

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM