javascript - ServiceWorker 阻止任何外部资源

标签 javascript service-worker offline offline-caching

我已经实现了 ServiceWorker在我的一些网络应用程序上利用离线功能和一些与 ServiceWorkers 相关的其他好东西。现在,一切正常,直到我添加了一些外部嵌入式脚本。我在我的网络应用程序中添加了大约 3 个外部脚本。其中一些获取广告并将其显示在我的应用程序上,其中一些用于收集分析。

但是,令我惊讶的是,当启用 ServiceWorkers 时,每个外部脚本都会失败,并在控制台中抛出以下错误

enter image description here

我不确定为什么会这样?我是否必须在 ServiceWorker 中以某种方式缓存这些脚本?任何帮助将不胜感激。

这是我添加到我的应用程序中的 ServiceWorker 代码。

importScripts('js/cache-polyfill.js');

var CACHE_VERSION = 'app-v18';
var CACHE_FILES = [
    '/',
    'index.html',
    'js/app.js',
    'js/jquery.min.js',
    'js/bootstrap.min.js',
    'css/bootstrap.min.css',
    'css/style.css',
    'favicon.ico',
    'manifest.json',
    'img/icon-48.png',
    'img/icon-96.png',
    'img/icon-144.png',
    'img/icon-196.png'
];

self.addEventListener('install', function (event) {
    event.waitUntil(
        caches.open(CACHE_VERSION)
            .then(function (cache) {
                console.log('Opened cache');
                return cache.addAll(CACHE_FILES);
            })
    );
});

self.addEventListener('fetch', function (event) {
    event.respondWith(
        caches.match(event.request).then(function(res){
            if(res){
                return res;
            }
            requestBackend(event);
        })
    )
});

function requestBackend(event){
    var url = event.request.clone();
    return fetch(url).then(function(res){
        //if not a valid response send the error
        if(!res || res.status !== 200 || res.type !== 'basic'){
            return res;
        }

        var response = res.clone();

        caches.open(CACHE_VERSION).then(function(cache){
            cache.put(event.request, response);
        });

        return res;
    })
}

self.addEventListener('activate', function (event) {
    event.waitUntil(
        caches.keys().then(function(keys){
            return Promise.all(keys.map(function(key, i){
                if(key !== CACHE_VERSION){
                    return caches.delete(keys[i]);
                }
            }))
        })
    )
});

最佳答案

以下是我为解决该问题所做的工作。

我尝试使用 Navigator.onLine 检查应用程序是否在线fetch 事件监听器中的 API,如果在线,则提供来自服务器的响应,否则来自 ServiceWorker。这样,应用程序在线时请求就不会被阻止,从而解决了这个特定问题。

下面是我的实现方式。

self.addEventListener('fetch', function (event) {
    let online = navigator.onLine;
    if(!online){
      event.respondWith(
          caches.match(event.request).then(function(res){
              if(res){
                  return res;
              }
              requestBackend(event);
          })
      )
    }
});

您还可以在此处查看整个 ServiceWorker 脚本:https://github.com/amitmerchant1990/notepad/blob/master/sw.js

关于javascript - ServiceWorker 阻止任何外部资源,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51700513/

相关文章:

javascript - Chart.js 不使用 mySQL 数据库中的数据呈现图表

service-worker - event.waitUntil 在推送事件监听器中调用时引发错误

android - 使用 ArcGIS 创建离线 map (.mmpk map )

html - 开发稳定的 HTML5 离线应用程序?

javascript - Highcharts 仅在彩色区域检测 mouseOver 事件

javascript - 如何解决 Angular 中的这个路线问题?

javascript - 我如何做 JavaScript 原型(prototype)继承(原型(prototype)链)

javascript - Service Worker 更新延迟

Angular 5 应用程序未注册服务 worker

svn - 离线工作的颠覆代理?