V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
lbfeng
V2EX  ›  JavaScript

service work 能主动向 main script 发 message 吗?

  •  
  •   lbfeng · 2019-10-24 06:46:05 +08:00 · 2419 次点击
    这是一个创建于 1857 天前的主题,其中的信息可能已经有所发展或是发生改变。

    怎么在 push callback 里向 main script 发 message? service-worker.js

    console.log("Service Worker Loaded...");
    self.addEventListener("push", e => {
      const data = e.data.json();
      console.log("Push Recieved...");
      // post data back to main script
    });
    
    1 条回复    2019-10-25 02:31:21 +08:00
    lbfeng
        1
    lbfeng  
    OP
       2019-10-25 02:31:21 +08:00
    我自己挖的坑自己填吧。

    service worker 可以得到所有的 clients 也就是所有 register 过这个 service worker 的 script.

    ```javascript
    function sendMessage(message) {
    return self.clients.matchAll({
    includeUncontrolled: true // https://developer.mozilla.org/en-US/docs/Web/API/Clients/matchAll
    }).then(clients => {
    // post messages
    // only has one client
    clients[0].postMessage(message);
    });
    }
    ```
    在 push event 的 callback function 里调用 sendMessage 就可以吧 remote push message 传回 client.
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2763 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 04:06 · PVG 12:06 · LAX 20:06 · JFK 23:06
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.