跳转到主内容

Class: ServiceWorkers

Class: ServiceWorkers

从活跃的 service worker 会话中查询和接收事件

Process: Main
此类不从 'electron' 模块导出. 它只能作为 Electron API 中其他方法的返回值。

通过SessionserviceWorkers属性来访问ServiceWorkers的实例

例如:

const { session } = require('electron')

// Get all service workers.
console.log(session.defaultSession.serviceWorkers.getAllRunning())

// Handle logs and get service worker info
session.defaultSession.serviceWorkers.on('console-message', (event, messageDetails) => {
console.log(
'Got service worker message',
messageDetails,
'from',
session.defaultSession.serviceWorkers.getFromVersionID(messageDetails.versionId)
)
})

实例事件

ServiceWorkers实例中有下列事件:

Event: 'console-message'

返回:

  • event Event
  • messageDetails Object - 有关控制台消息的信息
    • message string - 实际控制台消息
    • versionId number - 发送消息日志的 service worker 的版本 ID
    • source string - 消息源的类型 可以是 javascript, xml, network, console-api, storage, rendering, security, deprecation, worker, violation, intervention, recommendationother
    • level number - 日志等级,从 0 到 3 。 按顺序匹配 verbose, info, warningerror.
    • sourceUrl string - 消息来源的URL
    • lineNumber number - 触发此控制台消息的源码的行号。

当一个service worker记录日志到控制台的时候将自动触发此事件

Event: 'registration-completed'

返回:

  • event Event
  • details Object - 有关 service worker 注册的信息
    • scope string - 当前 service worker 所注册在的URL

当一个service worker已经被注册完成的时候触发此事件。 注册完成分两种情况, 一个是调用navigator.serviceWorker.register('/sw.js')方法成功,另一个是当Chrome的扩展加载结束。

实例方法

ServiceWorkers实例对象中,有以下方法:

serviceWorkers.getAllRunning()

返回 Record<number, ServiceWorkerInfo> , 一个 ServiceWorkerInfo 对象, 其中键是 service worker 的版本 ID ,值是 service worker 的信息。

serviceWorkers.getFromVersionID(versionId)

  • versionId number

返回 ServiceWorkerInfo - service worker的相关信息

如果 service worker 不存在或者停止运行,此方法将抛出异常。