Chrome 扩展支持
Electron 支持一部分 Chrome 扩展 API,主要用于支持 DevTools 扩展和 Chromium 内部扩展,但同时也支持一些其他的扩展功能。
Electron 不支持商店中的任意 Chrome 扩展,并且 Electron 项目的**目标**并非与 Chrome 的扩展实现完全兼容。
加载扩展
Electron 仅支持加载未打包的扩展(即 .crx 文件无效)。扩展是按 session 安装的。要加载扩展,请调用 ses.extensions.loadExtension
const { session } = require('electron')
session.defaultSession.loadExtension('path/to/unpacked/extension').then(({ id }) => {
// ...
})
加载的扩展不会自动在退出后被记住;如果您在应用程序运行时没有调用 loadExtension,则扩展将不会被加载。
请注意,加载扩展仅在持久会话中受支持。尝试将扩展加载到内存会话中将引发错误。
有关加载、卸载和查询活动扩展的更多信息,请参阅 session 文档。
支持的扩展 API
我们支持以下扩展 API,但有一些限制。其他 API 可能会被支持,但对此处未列出的任何 API 的支持是临时的,可能会被移除。
支持的 Manifest 键
nameversionauthorpermissionscontent_scriptsdefault_localedevtools_pageshort_namehost_permissions(Manifest V3)manifest_versionbackground(Manifest V2)minimum_chrome_version
有关每个可能键的用途的更多信息,请参阅 Manifest 文件格式。
chrome.devtools.inspectedWindow
此 API 的所有功能都受支持。
有关更多信息,请参阅 官方文档。
chrome.devtools.network
此 API 的所有功能都受支持。
有关更多信息,请参阅 官方文档。
chrome.devtools.panels
此 API 的所有功能都受支持。
有关更多信息,请参阅 官方文档。
chrome.extension
支持 chrome.extension 的以下属性
chrome.extension.lastError
支持 chrome.extension 的以下方法
chrome.extension.getURLchrome.extension.getBackgroundPage
有关更多信息,请参阅 官方文档。
chrome.management
支持 chrome.management 的以下方法
chrome.management.getAllchrome.management.getchrome.management.getSelfchrome.management.getPermissionWarningsByIdchrome.management.getPermissionWarningsByManifest
支持 chrome.management 的以下事件
chrome.management.onEnabledchrome.management.onDisabled
有关更多信息,请参阅 官方文档。
chrome.runtime
支持 chrome.runtime 的以下属性
chrome.runtime.lastErrorchrome.runtime.id
支持 chrome.runtime 的以下方法
chrome.runtime.getBackgroundPagechrome.runtime.getManifestchrome.runtime.getPlatformInfochrome.runtime.getURLchrome.runtime.connectchrome.runtime.sendMessagechrome.runtime.reload
支持 chrome.runtime 的以下事件
chrome.runtime.onStartupchrome.runtime.onInstalledchrome.runtime.onSuspendchrome.runtime.onSuspendCanceledchrome.runtime.onConnectchrome.runtime.onMessage
有关更多信息,请参阅 官方文档。
chrome.scripting
此 API 的所有功能都受支持。
有关更多信息,请参阅 官方文档。
chrome.storage
支持 chrome.storage 的以下方法
chrome.storage.local
chrome.storage.sync 和 chrome.storage.managed **不**受支持。
有关更多信息,请参阅 官方文档。
chrome.tabs
支持 chrome.tabs 的以下方法
chrome.tabs.sendMessagechrome.tabs.reloadchrome.tabs.executeScriptchrome.tabs.query(部分支持)- 支持的属性:
url、title、audible、active、muted。
- 支持的属性:
chrome.tabs.update(部分支持)- 支持的属性:
url、muted。
- 支持的属性:
在 Chrome 中,将 -1 作为选项卡 ID 传递表示“当前活动选项卡”。由于 Electron 没有此概念,因此将 -1 作为选项卡 ID 传递不受支持,并将引发错误。
有关更多信息,请参阅 官方文档。
chrome.webRequest
此 API 的所有功能都受支持。
如果存在冲突的处理程序,Electron 的 webRequest 模块优先于 chrome.webRequest。
有关更多信息,请参阅 官方文档。