首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >@angular/service-worker静默失败

@angular/service-worker静默失败
EN

Stack Overflow用户
提问于 2017-12-23 04:15:48
回答 1查看 253关注 0票数 0

我已经在几个项目中成功地使用了@angular/service-worker模块,但在我最新的项目中遇到了一个似乎无法调试的静默失败问题。我的配置和设置与其他项目相同,并且输出的构建(通过CLI v1.6.2)似乎是正确的:

dist (partial)

我最初的想法是我的环境变量有问题,所以我检查了日志以确保enabled在构建后是true的,甚至为了测试在所有环境中都硬编码了它:

代码语言:javascript
复制
ServiceWorkerModule.register('/ngsw-worker.js', {
  enabled: true
})

然而,当我运行应用程序时,无论是在本地使用http-server,还是在启用了prod模式的开发或qa环境中,开发工具中都没有注册服务工作者,控制台中也没有错误或警告:

service worker tab

在这种情况下,有没有人知道是什么导致了静默失败?我绞尽脑汁,将有效的解决方案与此进行比较,但似乎无法提出解决方案。另外,有没有办法进一步调试这种类型的场景?

提前感谢您的帮助!

EN

回答 1

Stack Overflow用户

发布于 2018-03-27 01:11:44

您可以在main.ts文件中使用此解决方法:

代码语言:javascript
复制
platformBrowserDynamic().bootstrapModule(AppModule).then(() => {
  if ('serviceWorker' in navigator && environment.production) {
    navigator.serviceWorker.register('/ngsw-worker.js');
  }
}).catch(err => console.log(err));

正如here所解释的,您的代码库或依赖项中可能存在一些问题。在angular团队给出官方解决方案之前,我更倾向于使用变通解决方案。

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

https://stackoverflow.com/questions/47946919

复制
相关文章

相似问题

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