首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >workbox serviceworker在除Chrome之外的任何地方工作: Uncaught (in promise) DOMException

workbox serviceworker在除Chrome之外的任何地方工作: Uncaught (in promise) DOMException
EN

Stack Overflow用户
提问于 2019-01-15 19:34:35
回答 3查看 4.1K关注 0票数 4

Workbox不能在Chrome上工作,但它在其他地方都能工作,这很讽刺,因为我相信这是一个Google库,显示的错误是:

代码语言:javascript
复制
Uncaught (in promise) DOMException : sw.js line 1

Chrome:

歌剧

Firefox

我使用的是workbox-webpack-plugin

webpack.config.js

代码语言:javascript
复制
    const workbox = require('workbox-webpack-plugin'); 

    module.exports = {
        plugins: [
            new workbox.GenerateSW({
                swDest: './service-worker.js',
                skipWaiting: true,
                clientsClaim: true
            })
        ]  
 }

index.ts (条目)

代码语言:javascript
复制
if ('serviceWorker' in navigator) {
  window.addEventListener('load', function() {
    navigator.serviceWorker.register('/js/app/dist/service-worker.js');
  }); 
}

EDIT:这是抛出错误的代码行

编辑2:它实际上在icognito模式下工作,删除浏览器数据仍然没有帮助。

编辑3:更新到最新的测试版1更糟糕,因为除了最新的错误之外,它还会显示另一个错误,然而,这个版本也可以在Chrome的icognito模式和其他浏览器中运行。

EN

回答 3

Stack Overflow用户

发布于 2019-01-22 02:14:42

如果浏览器超出分配的磁盘空间配额,则通常会引发此错误。您的隐身正在工作,因为它将被分配新的磁盘配额,而正常情况下选项卡共享相同的磁盘配额。

你能在devtools中打开Application标签并点击Clear storage > Clear site data吗?在大多数情况下,这应该可以解决这个问题。

票数 5
EN

Stack Overflow用户

发布于 2019-02-07 05:12:52

Chrome自动升级到了72版本,现在它适用于我和我的同事。它很可能是一个已修复的bug。

票数 1
EN

Stack Overflow用户

发布于 2019-01-21 17:00:00

你可能把SW文件的作用域弄错了。试试这个:

代码语言:javascript
复制
if ('serviceWorker' in navigator) {
  window.addEventListener('load', function() {
    navigator.serviceWorker.register('/js/app/dist/service-worker.js', { scope: '/' });
  }); 
}

如果无法移动SW文件,则需要在后端添加一个特殊的头部:

代码语言:javascript
复制
Server {

    listen www.example.com:443 ssl;

    ...

    location /js/app/dist/service-worker.js {
        add_header 'Service-Worker-Allowed' '/';
    }
}

(nginx配置)

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54198028

复制
相关文章

相似问题

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