跳过主内容

Electron 20.0.0

·阅读 4 分钟

Electron 20.0.0 已发布!它包括 Chromium 104、V8 10.4 和 Node.js 16.15.0 的升级。阅读下文了解更多详情!


Electron 团队很高兴地宣布 Electron 20.0.0 已发布!您可以通过 npm 安装它:npm install electron@latest,或者从我们的发布网站下载。请继续阅读以了解此版本的详细信息,并欢迎分享您的反馈!

值得注意的变更

新功能

  • 在 Windows 上添加了沉浸式深色模式。#34549
  • 添加了面板式行为支持。窗口可以浮动在全屏应用上方。#34665
  • 更新了 Windows 控制覆盖按钮,使其在 Windows 11 上看起来和感觉更原生。#34888
  • 现在,渲染器默认是沙盒化的,除非指定了 nodeIntegration: truesandbox: false#35125
  • 在使用 nan 构建原生模块时添加了安全防护。#35160

技术栈变更

重大变更和 API 变更

以下是 Electron 20 中引入的重大变更。有关这些变更以及未来变更的更多信息,请参阅计划中的重大变更页面。

默认变更:未指定 nodeIntegration: true 的渲染器默认进行沙盒化

以前,指定了预加载脚本的渲染器默认是非沙盒化的。这意味着默认情况下,预加载脚本可以访问 Node.js。在 Electron 20 中,此默认设置已更改。从 Electron 20 开始,渲染器将默认进行沙盒化,除非指定了 nodeIntegration: truesandbox: false

如果您的预加载脚本不依赖于 Node,则无需采取任何措施。如果您的预加载脚本确实依赖于 Node,则可以重构它们以从渲染器中删除 Node 的使用,或者为相关渲染器显式指定 sandbox: false

修复:nan 原生模块中意外崩溃的问题

在 Electron 20 中,我们更改了与原生模块相关的两项内容:

  1. V8 头文件现在默认使用 c++17。此标志已添加到 electron-rebuild 中。
  2. 我们修复了一个问题,即缺少头文件会导致依赖 nan 的原生模块意外崩溃。

为获得最佳稳定性,我们建议在重新构建原生模块(特别是依赖 nan 的模块)时使用 node-gyp >=8.4.0 和 electron-rebuild >=3.2.9。有关更多信息,请参阅 electron #35160 和 node-gyp #2497

已移除:Linux 上的 .skipTaskbar

在 X11 上,skipTaskbar 向 X11 窗口管理器发送 _NET_WM_STATE_SKIP_TASKBAR 消息。Wayland 没有直接等效的功能,已知的工作方法存在不可接受的权衡(例如 GNOME 中的 Window.is_skip_taskbar 需要不安全模式),因此 Electron 无法在 Linux 上支持此功能。

17.x.y 停止支持

根据项目的支持政策,Electron 17.x.y 已达到支持终止。建议开发人员和应用程序升级到更新的 Electron 版本。

E18 (22年3月)E19 (22年5月)E20 (22年8月)E21 (22年9月)E22 (22年12月)
18.x.y19.x.y20.x.y21.x.y22.x.y
17.x.y18.x.y19.x.y20.x.y21.x.y
16.x.y17.x.y18.x.y19.x.y20.x.y
15.x.y--------

后续计划

短期内,您可以期待团队将继续专注于与构成 Electron 的主要组件(包括 Chromium、Node 和 V8)的开发保持同步。尽管我们谨慎地不承诺发布日期,但我们的计划是大约每 2 个月发布一个包含这些组件新版本的新 Electron 主要版本。

您可以在此处找到 Electron 的公开时间表。

有关未来变更的更多信息,请参见计划中的重大变更页面。