跳转到主要内容

Electron 3.0.0

·6 分钟阅读

Electron 团队很高兴地宣布,Electron 3 的第一个稳定版本现已在 electronjs.org 和通过 npm install electron@latest 发布!它包含大量升级、修复和新功能,我们迫不及待地想看到您将使用它们构建出什么。以下是此版本的一些详细信息,欢迎您在探索过程中提供反馈。


发布流程

在开发 v3.0.0 的过程中,我们试图通过规范化渐进式 beta 版本反馈流程来更实证地定义稳定版本的标准。v3.0.0 的发布离不开我们的 应用反馈计划 合作伙伴,他们在 beta 期间提供了早期测试和反馈。感谢 Atlassian、Atom、Microsoft Teams、Oculus、OpenFin、Slack、Symphony、VS Code 以及其他计划成员的辛勤工作。如果您想参与未来的 beta 测试,请发送邮件至 info@electronjs.org

更改 / 新功能

Electron 工具链的一些重要部分进行了重大更新,包括 Chrome v66.0.3359.181、Node v10.2.0 和 V8 v6.6.346.23

  • [#12656] feat: app.isPackaged
  • [#12652] feat: app.whenReady()
  • [#13183] feat: process.getHeapStatistics()
  • [#12485] feat: win.moveTop() 用于将窗口 z 轴顺序移到最上面
  • [#13110] feat: TextField 和 Button API
  • [#13068] feat: netLog API 用于动态日志控制
  • [#13539] feat: 在沙盒渲染器中启用 webview
  • [#14118] feat: fs.readSync 现在可以处理大型文件
  • [#14031] feat: node fs 包装器,使 fs.realpathSync.nativefs.realpath.native 可用

API 重大更改

  • [#12362] feat: 更新菜单项顺序控制
  • [#13050] refactor: 移除已文档化并弃用的 API
    • 有关更多详细信息,请参阅 文档
  • [#12477] refactor: 移除 did-get-response-detailsdid-get-redirect-request 事件
  • [#12655] feat: 默认禁用拖放导航
  • [#12993] feat: 使用 electron npm 模块需要 Node v4.x 或更高版本
  • [#12008 #12140 #12503 #12514 #12584 #12596 #12637 #12660 #12696 #12716 #12750 #12787 #12858] refactor: NativeWindow
  • [#11968] refactor: menu.popup()
  • [#8953] feat: 不再使用 JSON 发送 ipcRenderer.sendSync 的结果
  • [#13039] feat: 默认忽略 URL 后面的命令行参数
  • [#12004] refactor: 将 api::Window 重命名为 api::BrowserWindow
  • [#12679] feat: 视觉缩放默认关闭
  • [#12408] refactor: 将 app-command media-play_pause 重命名为 media-play-pause

macOS

  • [#12093] feat: 工作区通知支持
  • [#12496] feat: tray.setIgnoreDoubleClickEvents(ignore) 用于忽略托盘双击事件。
  • [#12281] feat: macOS 上的鼠标前进功能
  • [#12714] feat: 屏幕锁定/解锁事件

Windows

  • [#12879] feat: 添加了 DIP 与屏幕坐标的转换

请注意: 在运行此版本后切换到旧版本 Electron 时,需要清除用户数据目录以避免旧版本崩溃。您可以通过运行 console.log(app.getPath("userData")) 获取用户数据目录,或参阅 文档 了解更多详细信息。

Bug 修复

  • [#13397] fix: fs.statSyncNoException 抛出异常的问题
  • [#13476, #13452] fix: 加载包含 jquery 的网站时崩溃
  • [#14092] fix: net::ClientSocketHandle 析构函数中的崩溃
  • [#14453] fix: 立即通知焦点更改,而不是在下一个 tick

macOS

  • [#13220] fix: 允许在 <input file="type"> 打开文件对话框中选择 bundle 的问题
  • [#12404] fix: 使用异步对话框时阻止主进程的问题
  • [#12043] fix: 上下文菜单点击回调
  • [#12527] fix: 重用 touchbar 项目时发生的事件泄漏
  • [#12352] fix: 托盘标题崩溃
  • [#12327] fix: 非拖动区域
  • [#12809] fix: 防止在菜单打开时更新菜单
  • [#13162] fix: 托盘图标边界不允许负值
  • [#13085] fix: 托盘标题高亮时未反转
  • [#12196] fix: Mac 构建时 enable_run_as_node==false 的问题
  • [#12157] fix: 无边框窗口配合 vibrancy 时的额外问题
  • [#13326] fix: 在调用 app.removeAsDefaultProtocolClient 后设置 mac 协议为 none
  • [#13530] fix: MAS 构建中私有 API 的不正确使用
  • [#13517] fix: tray.setContextMenu 崩溃
  • [#14205] fix: 按下 escape 键关闭对话框,即使设置了 defaultId

Linux

  • [#12507] fix: BrowserWindow.focus() 对离屏窗口的处理

其他说明

  • PDF 查看器目前无法工作,但我们正在积极修复,并将尽快恢复其功能。
  • TextFieldButton API 仍处于实验阶段,因此默认关闭。
    • 可以通过 enable_view_api 构建标志启用它们。

下一步计划

Electron 团队将继续努力定义更快速、更顺畅的升级流程,以期最终与 Chromium、Node 和 V8 的开发节奏保持一致。