【问题标题】:How to change scope variable when push notification received收到推送通知时如何更改范围变量
【发布时间】:2019-06-17 09:20:28
【问题描述】:

我的网络应用中有一个通知图标,显示通知的数量。应用程序的前端是使用 angularjs 制作的。

图标的计数存储在$rootScope 变量中。我想在收到推送通知时增加变量(或调用返回计数的 Web 服务)。

serviceworker.js 文件无权访问 angularjs 中的范围变量。如何从服务人员更改计数变量的值。

我想在 localStorage 项目上添加一个更改事件侦听器。

登录后,我将创建一个项目。

localStorage.setItem('notifCount', 0);

当我收到推送通知时,我将在localStorage 中增加notifCountserviceworker.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


【解决方案1】:

数据通过消息系统在worker和主线程之间发送——双方使用postMessage()方法发送消息,并通过onmessage事件处理程序响应消息(消息包含在Message事件的data 属性。)数据被复制而不是共享。

有关详细信息,请参阅

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2022-11-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多