跳转到主要内容

ARM 上的 Windows

如果您的应用程序运行的是 Electron 6.0.8 或更高版本,现在可以为 Windows 10 on Arm 构建它。这能显著提高性能,但需要重新编译应用程序中使用的任何原生模块。它也可能需要对您的构建和打包脚本进行一些小的修复。

运行基本应用

如果您的应用程序不使用任何原生模块,那么创建该应用程序的 Arm 版本非常容易。

  1. 确保您应用程序的 node_modules 目录为空。
  2. 使用命令提示符,在运行 npm install/yarn install(一如既往)之前,运行 set npm_config_arch=arm64
  3. 如果 Electron 已作为开发依赖项安装,npm 将下载并解压 arm64 版本。然后您可以像平常一样打包和分发您的应用程序。

通用注意事项

特定于体系结构的 कोड

许多特定于 Windows 的代码包含 if...else 逻辑,用于在 x64 或 x86 体系结构之间进行选择。

if (process.arch === 'x64') {
// Do 64-bit thing...
} else {
// Do 32-bit thing...
}

如果您想以 arm64 为目标,这样的逻辑通常会选择错误的体系结构,因此请仔细检查您的应用程序和构建脚本中是否存在此类条件。在自定义构建和打包脚本中,您应该始终检查环境变量 npm_config_arch 的值,而不是依赖于当前进程的体系结构。

原生模块

如果您使用原生模块,则必须确保它们使用 MSVC 编译器 v142(提供于 Visual Studio 2017)进行编译。您还必须检查原生模块提供或引用的任何预构建的 .dll.lib 文件是否适用于 Windows on Arm。

测试您的应用

要测试您的应用程序,请使用运行 Windows 10(版本 1903 或更高版本)的 Windows on Arm 设备。请确保将应用程序复制到目标设备 - 当从网络位置加载应用程序资产时,Chromium 的沙箱将无法正常工作。

开发先决条件

Node.js/node-gyp

建议使用 Node.js v12.9.0 或更高版本。 如果不想更新到新的 Node 版本,您可以改为手动更新 npm 的 node-gyp 副本到 5.0.2 或更高版本,其中包含编译 Arm 原生模块所需的更改。

Visual Studio 2017

交叉编译原生模块需要 Visual Studio 2017(任何版本)。您可以通过 Microsoft 的Visual Studio Dev Essentials 程序下载 Visual Studio Community 2017。安装后,您可以从命令提示符运行以下命令来添加 Arm 特定组件:

vs_installer.exe ^
--add Microsoft.VisualStudio.Workload.NativeDesktop ^
--add Microsoft.VisualStudio.Component.VC.ATLMFC ^
--add Microsoft.VisualStudio.Component.VC.Tools.ARM64 ^
--add Microsoft.VisualStudio.Component.VC.MFC.ARM64 ^
--includeRecommended

创建交叉编译命令提示符

在环境变量中设置 npm_config_arch=arm64 会创建正确的 arm64 .obj 文件,但标准的适用于 VS 2017 的开发者命令提示符将使用 x64 链接器。要解决此问题,请执行以下操作:

  1. 复制“适用于 VS 2017 的 x64_x86 交叉工具命令提示符”快捷方式(例如,通过在开始菜单中找到它,右键单击,选择打开文件位置,然后复制并粘贴)到方便的位置。
  2. 右键单击新快捷方式并选择属性
  3. 目标字段的末尾从 vcvarsamd64_x86.bat 更改为 vcvarsamd64_arm64.bat

如果操作成功,命令提示符在启动时应显示类似如下内容:

**********************************************************************
** Visual Studio 2017 Developer Command Prompt v15.9.15
** Copyright (c) 2017 Microsoft Corporation
**********************************************************************
[vcvarsall.bat] Environment initialized for: 'x64_arm64'

如果您想直接在 Windows on Arm 设备上开发应用程序,请将目标中的 vcvarsx86_arm64.bat 替换为 vcvarsamd64_arm64.bat,以便可以使用设备的 x86 仿真进行交叉编译。

链接到正确的 node.lib

默认情况下,node-gyp 会解压 Electron 的节点头文件,并将 x86 和 x64 版本的 node.lib 下载到 %APPDATA%\..\Local\node-gyp\Cache,但不会下载 arm64 版本(修复此问题的工作正在进行中)。要解决此问题:

  1. https://electron.js.cn/headers/v6.0.9/win-arm64/node.lib 下载 arm64 node.lib
  2. 将其移动到 %APPDATA%\..\Local\node-gyp\Cache\6.0.9\arm64\node.lib

6.0.9 替换为您正在使用的版本。

交叉编译原生模块

完成以上所有步骤后,打开您的交叉编译命令提示符,然后运行 set npm_config_arch=arm64。然后使用 npm install 像往常一样构建您的项目。与交叉编译 x86 模块一样,如果原生模块之前已为其他体系结构编译过,您可能需要删除 node_modules 以强制重新编译原生模块。

调试原生模块

可以使用 Visual Studio 2017(在您的开发机器上运行)和在目标设备上运行的相应 Visual Studio 远程调试器来调试原生模块。要进行调试:

  1. 通过命令提示符在目标设备上启动您的应用程序 .exe(传递 --inspect-brk 在任何原生模块加载之前暂停它)。
  2. 在您的开发机器上启动 Visual Studio 2017。
  3. 通过选择调试 > 附加到进程... 连接到目标设备,并输入 Visual Studio 远程调试器工具显示的设备 IP 地址和端口号。
  4. 点击刷新并选择相应的 Electron 进程进行附加
  5. 您可能需要确保您应用程序中原生模块的任何符号都已正确加载。要配置此项,请在 Visual Studio 2017 中转到调试 > 选项...,然后在调试 > 符号下添加包含 .pdb 符号的文件夹。
  6. 附加后,设置任何适当的断点,并使用 Chrome 的 Node 远程工具恢复 JavaScript 执行。

获取额外帮助

如果您在此文档中遇到问题,或者您的应用程序在为 x86 编译时工作但在为 arm64 编译时不工作,请提交 issue,并在标题中包含“Windows on Arm”。