HarmonyOS 5中UniApp的调试步骤

在 HarmonyOS 5 中调试 UniApp 应用的完整步骤如下,涵盖环境配置、设备连接及调试方法:

一、环境准备

  1. 开发工具

    • 安装 HBuilderX 4.64+(需启用鸿蒙插件)
    • 可选安装 DevEco Studio 5.0.3+(用于真机调试)
    • 配置 Node.js ≥18.x:
TypeScript 复制代码
npm install -g @dcloudio/uni-cli  # 安装 UniApp CLI

‌2.项目配置

manifest.json 声明鸿蒙平台:

TypeScript 复制代码
"harmonyos": {
  "appType": "ohos",
  "packageName": "com.example.app",  // 需与 AGC 应用包名一致
  "minPlatformVersion": 5
}

二、设备连接

1. ‌USB 真机调试
  • 鸿蒙设备开启开发者模式:
    设置 > 系统 > 开发者选项 > 启用 USB 调试
  • 连接电脑后,在设备弹窗点击 ‌允许 USB 调试
  • HBuilderX 选择菜单:运行 > 运行到鸿蒙设备
2. ‌无线跨设备调试
TypeScript 复制代码
hdc tconn 192.168.1.100  # 连接设备 IP
hdc list targets         # 验证设备状态

需确保设备与 PC 在同一局域网

3. ‌模拟器调试

在 DevEco Studio 的 ‌Device Manager‌ 启动多规格模拟器(如折叠屏、横竖屏)


🔍 三、调试方法

1. ‌日志输出
  • 使用 console 分级输出日志:
TypeScript 复制代码
console.debug('%{public}s', '敏感数据可见');  // public 确保日志可见
console.error('[MyApp] 网络超时');           // 按 tag 过滤日志
2. ‌可视化组件检查
  • 打开 ‌ArkUI Inspector ‌(DevEco Studio):
    View > Tool Windows > ArkUI Inspector
  • 查看编译后的组件层级,通过 data-test-id 定位元素:
TypeScript 复制代码
<button data-test-id="login_btn">登录</button> <!-- 源码 -->
3. ‌**断点调试(uni-app x 项目)**‌
  • 要求 HBuilderX 4.61+
  • 步骤:
    1. 点击控制台右上角 ‌蜘蛛按钮‌ 开启调试
    2. 在代码行号左侧双击设置断点
    3. 运行应用,触发断点暂停后查看变量/调用栈
4. ‌Webview 调试
  • EntryAbility.ets 开启调试支持:
TypeScript 复制代码
import webview from '@ohos.web.webview';
webview.WebviewController.setWebDebuggingAccess(true); // 启用 Web 调试
  • Chrome 访问 chrome://inspect 调试页面5

四、常见问题解决

  1. 设备未识别

    检查开发者选项中 ‌默认 USB 配置 ‌ 需设为 MIDI 或音频

  2. 断点失效

    仅支持 uni-app x 项目(Vue3 语法)

  3. 权限缺失

    module.json5 声明所需权限(如网络权限):

TypeScript 复制代码
"requestPermissions": [{
  "name": "ohos.permission.INTERNET",
  "usedScene": { "abilities": ["EntryAbility"] }
}]

五、发布前准备

  1. 证书配置
    • build-profile.json5 关联 AGC 正式签名证书
  2. 隐私合规
    • 敏感权限(相机/位置)需在 AGC 提交隐私协议说明

调试效率提升‌:

  • 多设备同步测试生命周期钩子与本地存储一致性
  • 使用 @ohos.hidebug 监控内存占用,避免重复渲染
相关推荐
cd_949217219 小时前
鸿蒙系统下抖音存储空间不足怎么办?缓存清理教程
缓存·华为·harmonyos
轻口味12 小时前
HarmonyOS 6.1 全栈实战录 - 14 渲染树透镜:FrameNode 渲染状态感知与高性能 UI 调优实战
ui·华为·harmonyos
HwJack2012 小时前
HarmonyOS NEXT 游戏APP开发中如何正确拦截退出手势
游戏·华为·harmonyos
HwJack2012 小时前
HarmonyOS APP开发中ArkTS/JS 类型错误全景拆解
javascript·华为·harmonyos
00后程序员张13 小时前
Windows 下怎么生成 AppStoreInfo.plist?不依赖 Xcode 的方法
ide·macos·ios·小程序·uni-app·iphone·xcode
lqj_本人13 小时前
鸿蒙PC:鸿蒙版本 Electron 框架环境搭建并且实现 XH 笔记应用
笔记·electron·harmonyos
不爱吃糖的程序媛13 小时前
特色软件 | 补齐 鸿蒙 PC 开发短板,Harmonybrew 的环境适配方案
华为·harmonyos
__zRainy__14 小时前
uni-app 全局容器实战系列(二):Vite 虚拟模块
windows·uni-app
Python私教14 小时前
端侧 AIGC 进 App:HarmonyOS Data Augmentation Kit 实测复盘
华为·aigc·harmonyos
__zRainy__14 小时前
uni-app 全局容器实战系列(一):全局容器的实现
uni-app·vite