【发布时间】:2019-06-17 09:20:28
【问题描述】:
我的网络应用中有一个通知图标,显示通知的数量。应用程序的前端是使用 angularjs 制作的。
图标的计数存储在$rootScope 变量中。我想在收到推送通知时增加变量(或调用返回计数的 Web 服务)。
serviceworker.js 文件无权访问 angularjs 中的范围变量。如何从服务人员更改计数变量的值。
我想在 localStorage 项目上添加一个更改事件侦听器。
登录后,我将创建一个项目。
localStorage.setItem('notifCount', 0);
当我收到推送通知时,我将在localStorage 中增加notifCount 在serviceworker.js 中,并且将触发更改事件。我可以在其中一个控制器文件中添加localStorage 更改侦听器并调用Web 服务,或者只是增加$rootScope 变量。
但即使有人在开发工具中手动更改 localStorage,也会发生这种情况。
我想知道我是否可以这样做(如果它是正确的方法)还是有更好的方法。我不觉得这是正确的方法。
【问题讨论】:
-
假设您在 Angular(客户端)和 service worker 之间进行了通信,您应该将 angular 变量的更新包装在 $apply 中。如果您还没有进行通信,请查看一些来自 google (craig-russell.co.uk/2016/01/29/…) 的 Service Worker 通信链接。
-
为此使用 locationStorage 似乎很奇怪。你可以例如在 app.run 中注册服务工作者侦听器并在那里更改 $rootScope 变量。
-
@PetrAveryanov 并且您无法在 serviceworker 中访问
localStorage
标签: javascript angularjs push-notification web-worker