ServiceWorker将承诺传递给FetchEvent.respondWith(),该承诺使用非响应值'undefined'解析。浏览器同步

时间:2017-05-13 17:51:45

标签: javascript node.js socket.io service-worker browser-sync

有时当我运行我的服务器时,控制台会给我一个错误:

  

无法加载   “http://localhost:3000/browser-sync/socket.io/?EIO=3&transport=polling&t=Lm2wn4p”。   ServiceWorker将承诺传递给FetchEvent.respondWith()   解决了非响应值'undefined'。

我不知道发生了什么,

Service-worker.js:

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

var CACHE_VERSION = 'app-v1';
var CACHE_FILES = [
    'index.html'
];

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('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]);
                }
            }))
        })
    )
});

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

任何想法或解决方案?

2 个答案:

答案 0 :(得分:2)

这只是一个缺少的return关键字:)

当在缓存中找到请求时,您返回响应,太棒了!但是当没有缓存时,你没有return语句,它最终将从你的requestBackend函数返回正确的响应,这会导致问题。

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

缩写:

caches.match(event.request).then(function(res){
  return res || requestBackend(event);
})

答案 1 :(得分:0)

这不是修复而是一种解决方法

您可以取消注册 Service Worker,以便网页重新加载/刷新缓存。

here 是您可以在 Firefox 上执行的操作。

here 是您在 chrome 上的操作方法