【问题标题】:Web push notifications not showing in Chrome网络推送通知未在 Chrome 中显示
【发布时间】:2018-03-22 11:49:35
【问题描述】:

目前我正在为我们的项目开发网络推送通知服务。我面临的问题是我在 Google Chrome 中的服务人员收到推送信号,但不会将其显示为通知,尽管我能够将数据记录到开发控制台。我在 Firefox 和其他设备的 Chrome 上尝试过它,它确实有效。我试图恢复 chrome 设置,但没有帮助。这是我的服务人员代码:

'use strict';

self.addEventListener('push', function(event) {
console.log('[Service Worker] Push Received.');
console.log(`[Service Worker] Push had this data: "${event.data.text()}"`);

var payloadJson = JSON.parse(event.data.text());

const title = payloadJson.title;
const options = {
    body: payloadJson.message,
    icon: 'img/img.png',
    badge: 'img/img2.png'
};

event.waitUntil(self.registration.showNotification(title, options));
});

推送服务工作者按预期记录消息后: Dev tools console log

正如我所提到的,我在 Chrome 上使用另一台具有 Chrome v64 的设备对其进行了测试,而我的设备是 v65.0.3325.162 两台设备都在 Mac OS High Sierra 10.13.3 上运行

编辑: 所以我发现了一些奇怪的行为,在完全删除带有所有缓存文件的 chrome 并重新安装它之后,我能够让它工作,但现在的问题是,如果我等到通知消失,下次就不会显示了。在我点击关闭通知之前一切正常。

【问题讨论】:

  • 你找到解决办法了吗?

标签: google-chrome push-notification notifications


【解决方案1】:

我发现如果showNotification()options 参数无效,即iconimage 字段中指定的文件不存在,则方法调用会静默解决而不引发错误或任何事情。这可能就是您看到push 事件进入但没有看到通知本身的原因。不过,我不确定与您在重新安装服务人员后解释的行为有什么联系。

【讨论】:

    【解决方案2】:

    要发送通知,有效负载必须使用notification key

    var payload = {
        notification: {
            title: 'My Title',
            body : 'TEST'
        }
    };
    

    看到这个答案:https://stackoverflow.com/a/47379794/2292766

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2016-07-22
      • 2019-08-06
      • 1970-01-01
      • 2019-12-22
      • 1970-01-01
      • 2019-05-13
      相关资源
      最近更新 更多