首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >广播频道api未触发,workbox

广播频道api未触发,workbox
EN

Stack Overflow用户
提问于 2018-11-13 18:15:50
回答 1查看 350关注 0票数 0

我是个新手,一直在尝试将它与我的react应用程序集成。缓存工作正常,但似乎broadcastUpdate不会在文件内容更改时触发。

这是在服务工作者中截取的代码:

代码语言:javascript
运行
复制
workbox.routing.registerRoute(/\.(?:css)$/,
  workbox.strategies.staleWhileRevalidate({
    cacheName: 'css-cache',
    broadcastUpdate: {
      channelName: 'api-updates'
    },
    plugins: [
      new workbox.broadcastUpdate.Plugin(
        'api-updates'
      )
    ]
  })
);

我正在我的主文件(index.js).Code片段中监听它

代码语言:javascript
运行
复制
const updatesChannel = new BroadcastChannel('api-updates');
updatesChannel.onmessage = function(e) {
  console.log('Received', e.data);
  alert('updated');
};

当css文件的内容发生变化时,updatesChannel中不会收到任何消息。

任何帮助都将不胜感激。谢谢。

EN

回答 1

Stack Overflow用户

发布于 2019-01-17 03:21:56

我也试过了,结果对我也一样..事实证明,客户端无法读取这些头文件。这是CORS的事情。对我来说,解决这个问题的方法是在Django设置中显式地添加这些头文件(或您使用的头文件):

代码语言:javascript
运行
复制
CORS_EXPOSE_HEADERS = ['Allow', 'Content-Length', 'ETag', 'Last-Modified', ] 
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53278675

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档