当前位置: 首页 > 知识库问答 >
问题:

一名服务人员向FetchEvent传递了一个promise。respondWith()使用非响应值“undefined”解析。浏览器同步

危砚
2023-03-14

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

未能加载'http://localhost:3000/browser-同步/套接字。io/?EIO=3

我不知道发生了什么,

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个答案

公羊灿
2023-03-14

这不是一个修复方案,而是一个解决方案

您可以注销service worker,以便网页重新加载/刷新缓存。

以下是您在firefox上的操作方法。

以下是您在chrome上的操作方法

狄兴邦
2023-03-14

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

当在缓存中找到请求时,返回响应,太好了!但是当没有缓存时,你没有返回语句,该语句最终会从你的请求后端函数返回正确的响应,这就导致了这个问题。

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);
})
 类似资料:
  • 有一个问题,我们的一些用户有一个错误的服务工作者坐在他们的Facebook浏览器从我们的网站。 问题:Facebook App用户在访问我们在FB上共享的页面时,会在FB浏览器上看到我们的“您离线页面”。 错误似乎是旧版本的Google Workbox(3.6.1)使用Chrome75自动返回FB应用程序中的您离线页面。更新Workbox修复了它。 对Workbox的引用在service work

  • 问题内容: 尝试将json字符串解析为android时,会传递HTML值。一天前一切正常,突然间,尝试通过php文件获取数据库时,我的应用突然崩溃了。 当我检查注意到html值时。请参阅logcat 我在byethost服务器上托管的所有页面都发生了这种情况,而在其他服务器上托管的页面运行良好。我尝试将我的文件之一移动到其他服务器,并在该文件上返回正确的json字符串。 另外,当我在浏览器中检查u

  • 我正在尝试调试我的<代码>。htaccess文件,其中包含: 在反复访问Safari中看到的同一网页时: 名称 = 包装.html, 方法 = GET, 状态 = 200 (正常), 类型 = 文本/html 名称=应用.html,方法=GET,状态=200(正常),类型=应用/x冲击波闪存 Chrome: 名称=包装器。html,方法=GET,状态=304(未修改),类型=text/html 名

  • 我有一个用于缓存图像的服务人员,这个服务人员只在前端模板中注册,但它仍会不断扩展到我的管理模板中。 这导致我的表单在验证令牌受到影响时表现得不可预测。 用一些安慰。日志我认为安装事件是在进入请求页面之前触发的,但我无法确定当前/下一个URL。 如何防止服务人员扩散到管理面板并干扰页面?我只想缓存资产。 就相关而言,这是我的服务人员:

  • 我使用两个解析服务器,一个用于主数据库,一个用于liveQuery。我还通过AWS ElastiCache设置了redis。问题是当我在客户端(iOS)中使用实时查询时,没有显示任何事件。代码对任何更改都没有响应。这里会有什么问题? 一个问题:来自AWS Elasticache的redisURL是这样的:(这会导致服务器启动错误)appname.jajj2i.0001.use1.cache.ama

  • 以下是我如何从集线器/节点设置开始进行所有设置... java-jar selenium-server-standalone-2.47.1.jar-role hub-maxinstances=10-maxsession=10-port 7777-timeout 29000 java-jar selenium-server-standalone-2.47.1.jar-role webdriver-h