Electron 14.0.0
Electron 14.0.0 已发布!它包括对 Chromium 93
和 V8 9.3
的升级。我们添加了一些 API 更新、错误修复和通用改进。阅读下文了解更多详情!
Electron 团队很高兴地宣布 Electron 14.0.0 发布!您可以通过 npm 使用 npm install electron@latest
安装它,或者从我们的发布网站下载。继续阅读以获取此版本的详细信息,并请分享您的任何反馈!
值得注意的变更
Electron 发布节奏变更
从 2021 年 9 月的 Electron 15 开始,Electron 将每 8 周发布一个新的主要稳定版本。您可以在此处阅读完整详情。Electron 15 将于 2021 年 9 月 1 日开始测试版,稳定版将于 2021 年 9 月 21 日发布。您可以在此处找到 Electron 的公开时间线。此外,Electron 将把支持的版本从最新的三个版本更改为最新的四个版本,直到 2022 年 5 月。有关 Electron 中版本控制的更详细信息,请参阅我们的版本控制文档。
堆栈变更
- Chromium
93
- Node.js
14.17.0
- V8
9.3
亮点功能
- 默认值已更改:
nativeWindowOpen
现在默认为true
。(参阅文档) - 子窗口不再从其父窗口继承 BrowserWindow 构造选项。#28550
- 新增
session.storagePath
API,用于获取会话特定数据的磁盘路径。#28665 - 新增
@electron/remote
使用的process.contextId
。#28007 - 在 Electron Fuse 后面添加了实验性 cookie 加密支持。#29492
有关新功能和更改的完整列表,请参阅 14.0.0 发布说明。
重大变更
以下是 Electron 14 中引入的重大变更。有关这些和未来变更的更多信息,请参阅计划的重大变更页面。
已移除:app.allowRendererProcessReuse
app.allowRendererProcessReuse
属性已移除,这是我们为了在安全性、性能和可维护性方面更紧密地与 Chromium 进程模型保持一致的计划的一部分。
欲了解更多详细信息,请参阅#18397。
已移除:浏览器窗口亲和性
创建新的 BrowserWindow
时,affinity
选项已移除,这是我们为了在安全性、性能和可维护性方面更紧密地与 Chromium 进程模型保持一致的计划的一部分。
欲了解更多详细信息,请参阅#18397。
API 变更:window.open()
可选参数 frameName
不再设置窗口标题。此行为现在遵循 原生文档 中 windowName
参数所描述的规范。
如果您曾使用此参数设置窗口标题,则可以改用 win.setTitle(title)
方法。
已移除:worldSafeExecuteJavaScript
worldSafeExecuteJavaScript
已移除,没有替代方案。请确保您的代码在此属性启用时仍能正常工作。自 Electron 12 起,此属性已默认启用。
如果您使用 webFrame.executeJavaScript
或 webFrame.executeJavaScriptInIsolatedWorld
,您将受到此变更的影响。您需要确保这些方法返回的值受 Context Bridge API 支持,因为这些方法使用相同的值传递语义。
默认值已更改:nativeWindowOpen
默认为 true
在 Electron 14 之前,window.open
默认使用 BrowserWindowProxy
进行填充。这意味着 window.open('about:blank')
无法打开可同步脚本化的子窗口,以及其他不兼容问题。nativeWindowOpen
不再是实验性的,现在是默认值。
有关更多详细信息,请参阅 Electron 中 window.open 的文档。
已移除:BrowserWindowConstructorOptions 从父窗口继承
在 Electron 14 之前,使用 window.open
打开的窗口会从其父窗口继承 BrowserWindow 构造选项,例如 transparent
和 resizable
。从 Electron 14 开始,此行为已被移除,窗口将不再从其父窗口继承任何 BrowserWindow 构造选项。
相反,请使用 setWindowOpenHandler
显式设置新窗口的选项。
webContents.setWindowOpenHandler((details) => {
return {
action: 'allow',
overrideBrowserWindowOptions: {
// ...
},
};
});
已移除:additionalFeatures
WebContents 的 new-window
和 did-create-window
事件中已弃用的 additionalFeatures
属性已移除。由于 new-window
使用位置参数,该参数仍然存在,但将始终为空数组 []
。(注意:new-window
事件本身已被弃用,并已替换为 setWindowOpenHandler
。)现在,窗口功能中的裸键将作为选项对象中值为 true
的键呈现。
// Removed in Electron 14
// Triggered by window.open('...', '', 'my-key')
webContents.on('did-create-window', (window, details) => {
if (details.additionalFeatures.includes('my-key')) {
// ...
}
});
// Replace with
webContents.on('did-create-window', (window, details) => {
if (details.options['my-key']) {
// ...
}
});
已移除:remote
模块
在 Electron 12 中弃用的 remote
模块现已从 Electron 本身中移除,并提取到一个单独的包中,即 @electron/remote
。@electron/remote
模块将主进程中的 JavaScript 对象桥接到渲染进程。这使您可以像在渲染进程中一样访问仅限于主进程的对象。它是 remote
模块的直接替代品。有关迁移说明和参考,请参阅模块的 README。
API 变更
- 新增
BrowserWindow.isFocusable()
方法以确定窗口是否可聚焦。#28642 - 新增
WebFrameMain.visibilityState
实例属性。#28706 - 为通过
setWindowOpenHandler
注册的窗口打开处理程序传递的 details 对象新增了disposition
、referrer
和postBody
。#28518 - 新增
@electron/remote
使用的process.contextId
。#28007 - 在 Electron Fuse 后面添加了实验性 cookie 加密支持。#29492
- 为
webRequest
监听器详细信息添加了缺失的resourceType
转换:font
、ping
、cspReport
、media
、webSocket
。#30050 - 新增
session.storagePath
API,用于获取会话特定数据的磁盘路径。#28665 - 新增 macOS 上对 Windows Control Overlay 的支持。#29986
- 新增对使用
--log-file=.../path/to/file.log
将 Chromium 日志定向到文件的支持。此外,现在可以在首次 JS 计时期间通过附加命令行开关从 JavaScript 启用日志记录。#29963 - 新增对 node crypto 中 des-ede3 密码的支持。#27897
- 新增
ContextBridgeMutability
功能,允许上下文桥接对象被修改。#27348
已移除/已弃用变更
以下 API 已移除或现已弃用
- 在 Electron 12 中弃用后,
remote
模块已移除。#25734 - 子窗口不再从其父窗口继承 BrowserWindow 构造选项。#28550
- 从
new-window
和did-create-window
WebContents 事件中移除了已弃用的additionalFeatures
属性。#28548 - 移除了已弃用的
app.allowRendererProcessReuse
和 BrowserWindowaffinity
选项。#26874 - 当
uploadToServer
为 false 时,crashReporter.start
的submitURL
选项不再是必需参数。#28105
11.x.y 版本支持结束
根据项目的支持策略,Electron 11.x.y 已达到支持终止。鼓励开发人员和应用程序升级到更新的 Electron 版本。
下一步
短期内,您可以期待团队继续专注于跟进构成 Electron 的主要组件(包括 Chromium、Node 和 V8)的开发。尽管我们谨慎地不承诺发布日期,但我们的计划是大约每季度发布带有这些组件新版本的新 Electron 主要版本。
有关 Electron 即将发布的版本中计划的重大变更信息,请参阅我们的计划的重大变更。