调试
实时重载
实时重载(Live Reload)对于在设备硬件上调试原生功能(例如插件)非常有用。无需每次代码更改后都部署新的原生二进制文件,它会在检测到应用中的更改时 重新加载浏览器(或 WebView)。了解更多。
iOS 和 Safari
Safari 可用于调试已连接的 iOS 设备或 iOS 模拟器上的 Ionic 应用。
首先,在 iOS 设备上,通过 设置 > Safari > 高级 启用 Web 检查器。
接着,在 Mac 上打开 Safari,然后在 Safari > 偏好设置 > 高级 下启用 在菜单栏中显示“开发”菜单。
运行 iOS 模拟器或将您的 iOS 设备连接到 Mac,然后运行您要调试的 Ionic 应用。
在 Safari 中,选择工具栏中的 开发。在下拉菜单选项中,您应该会看到您的设备和应用的名称。将鼠标悬停在应用名称上,然后单击 localhost。这将打开一个新的 Safari 开发者工具窗口——使用它们来检查和调试在您设备上运行的 Ionic 应用。
Android 和 Chrome
当应用使用 ionic serve 命令在浏览器中运行、部署到模拟器或运行在物理设备上时,可以使用 Google Chrome 的开发者工具进行调试。
要检查物理设备,首先需要启用开发者模式。将 Android 设备连接到计算机,然后进入 设置 > 关于,滚动到 版本号 并点击 7 次。这将在 设置 菜单中激活一个名为 开发者选项 的新选项。
接下来,进入 设置 > 开发者选项,确保开发者选项开关已打开。向下滚动到 USB 调试 并确保其也已启用。在 Android 模拟器中,开发者选项和 USB 调试默认是启用的。
打开 Chrome 浏览器并导航到 URL chrome://inspect/#devices。您连接的 Android 设备应出现在远程目标列表中。
在您的设备上,使用 Chrome 打开您想要调试的 Ionic 应用。
当您的应用在设备上运行时,返回 Chrome 并在远程目标列表中点击您设备下的 检查。这将在新窗口中打开 Chrome 开发者工具。然后,您可以使用所有 Chrome 开发者工具来调试在设备上运行的应用。
由于一个小错误,当您打开 Chrome 开发者工具时,应用预览可能不会自动出现。要使其出现,请点击 元素 选项卡,然后点击任何 DOM 元素,接着关闭并重新打开任何 CSS 规则,应用预览窗口就会显示出来。
在 Chrome 中使用 Visual Studio 进行本地调试(Android 和 iOS)
Visual Studio Code 也可用于调试在 Chrome 浏览器中运行的 Ionic 应用。
要进行此操作,请使用 ionic serve 在浏览器中运行您的应用。记下应用运行的端口。接下来,使用 Visual Studio Code 打开您的 Ionic 项目。
在 VS Code 最左侧的垂直菜单中,点击 运行 图标。如果这是您首次在项目中配置此功能,请点击创建 launch.json 文件的选项。从环境选项下拉菜单中选择 Chrome。这将自动生成一个 launch.json 文件,其中包含针对 localhost 启动 Chrome 的配置。
确保 launch.json 文件中 url 属性使用的端口与您之前运行 ionic serve 时观察到的端口一致。使用错误的端口号将无法工作。
在调试目标下拉菜单中,选择 针对 Chrome 启动,然后点击运行。这将打开一个新的 Chrome 浏览器实例,并且 VS Code 将附加到它。当您的应用在 Chrome 中运行时,您可以在 VS Code 中设置断点并使用其他调试工具。
在 Android 中使用 Visual Studio Code 进行调试
Visual Studio Code 有一个专用的插件,用于调 试在 Android WebView 中运行的应用。
该插件 在设备和 Visual Studio Code 开发者工具之间建立桥梁,并允许直接从编辑器进行调试。
要使用此插件调试您的 Ionic 应用,请先安装它,然后在 Android 模拟器中启动您的应用,或者连接您的 Android 设备并运行应用。您可能需要在 Android 设备上启用 USB 调试。
在您的 Ionic 项目根目录中,创建一个名为 .vscode 的文件夹,并在该文件夹内创建一个名为 launch.json 的文件。在 launch.json 中,输入以下代码来配置插件以调试 Ionic 应用:
{
"version": "0.2.0",
"configurations": [
{
"type": "android-webview",
"request": "attach",
"name": "附加到 Android WebView",
"webRoot": "${workspaceFolder}/www",
"sourceMaps": true,
"sourceMapPathOverrides": {
"webpack:/*": "${workspaceFolder}/*"
}
}
]
}
接下来,启动调试过程,选择您的设备和 Ionic 应用。VS Code 将附加到 Android 设备和 Ionic 应用,您现在可以调试您的应用,包括设置断点。
如果您无法设置断点并收到错误信息 "断点被忽略,因为未找到生成的代码(源映射问题?)",这意味着转译后的 JavaScript 文件路径不正确。使用调试控制台中的 .scripts 命令查看已加载的脚本。通过尝试 launch.json 配置文件中 sourceMapPathOverrides 键的不同值,确保脚本的路径是正确的。