【HarmonyOS Next之旅】DevEco Studio使用指南(三)

目录

[1 -> 一体化工程迁移](#1 -> 一体化工程迁移)

[1.1 -> 自动迁移](#1.1 -> 自动迁移)

[1.2 -> 手动迁移](#1.2 -> 手动迁移)

[1.2.1 -> API 10及以上历史工程迁移](#1.2.1 -> API 10及以上历史工程迁移)

[1.2.2 -> API 9历史工程迁移](#1.2.2 -> API 9历史工程迁移)


1 -> 一体化工程迁移

DevEco Studio从 NEXT Developer Beta1版本开始,提供开箱即用的开发体验,将SDK、Node.js、Hvigor、OHPM等工具链进行合一打包,简化DevEco Studio安装配置流程;并提供一体化的历史工程迁移能力,帮助开发者快速完成工程转换。

注意

为了避免数据丢失,迁移前请对工程进行备份。

一体化变更点如下:

|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 变更点 | 详细说明 |
| 删除compileSdkVersion字段 | 删除工程级build-profile.json5中的compileSdkVersion配置。 说明 * 由于targetSdkVersion未配置时值默认与compileSdkVersion的值一致,如果之前未配置targetSdkVersion,targetSdkVersion的值将与配套的SDK版本保持一致;如果之前配置过targetSdkVersion,targetSdkVersion的值不变。 * 若工程为Openharmony工程,则无需执行此步骤。 |
| 删除部分hvigor文件 & 删除冗余hvigor配置 | 1. 删除hvigor-wrapper.json。 2. 删除hvigorw、hvigorw.bat。 3. 删除hvigor-config.json5中的hvigorVersion字段,并删除dependencies中@ohos/hvigor-ohos-plugin及rollup字段。 |
| 删除HarmonyOS SDK配置 | 删除local.properties中的HarmonyOS SDK配置。若工程为Openharmony工程,则忽略此步骤。 |
| 增加开发态配置 | 1. 在hvigor-config.json5中增加开发态配置版本号modelVersion。 2. 在工程级的oh-package.json5中增加开发态配置版本号modelVersion。 |

1.1 -> 自动迁移

  1. 打开历史工程,Notifications 通知栏将出现"Sync failed."同步失败提示,点击Migrate Assistant,进入迁移助手页面。

说明

可以通过菜单栏Tools > Migrate Assistant,进入迁移助手页面。

  1. 在页面下方的Migrate Assistant 页签中选择迁移到5.0.0/5.0.1/5.0.2,并点击Migrate 按钮,此时将出现弹窗提示开发者进行数据备份。若确认已完成备份,请点击弹窗中Migrate,启动迁移任务。
  1. 待工程重新完成同步,并无其他报错提示,即为迁移成功。

说明

若工程是NPM管理的API 8/9工程,先按照适配OHPM包管理完成升级,再通过菜单栏Tools > Migrate Assistant,进入迁移助手页面,完成一体化工程自动迁移。

1.2 -> 手动迁移

1.2.1 -> API 10及以上历史工程迁移

如自动化迁移不成功或希望进行手动迁移,迁移前同样需对工程进行备份。手动迁移流程如下:

  1. 进入工程级build-profile.json5 文件,删除compileSdkVersion 配置。若工程为Openharmony工程,则无需删除compileSdkVersion字段。
  1. 删除并修改Hvigor相关文件:
  • 在左侧工程目录中删除hvigorw、hvigorw.bat 文件,并删除hvigor目录下的hvigor-wrapper.js文件。
  • 进入hvigor > hvigor-config.json5 文件中,新增modelVersion 字段,以API 12为例,其值为"5.0.0"。并删除hvigorVersion 字段、dependencies中的**@ohos/hvigor-ohos-plugin** 和rollup 字段**。**
  1. 在工程级oh-package.json5 文件中同样也需新增modelVersion字段,以API 12为例,其值为"5.0.0"。
  1. local.properties文件中,删除HarmonyOS SDK配置。若工程为Openharmony工程,则无需执行此步骤。
  1. 点击编辑界面上方Sync now 或进入菜单栏点击File > Sync and Refresh Project,重新进行工程同步。若无其他报错,至此历史工程手动迁移完成。

1.2.2 -> API 9历史工程迁移

  1. 将工程级build-profile.json5 文件中compileSdkVersion 字段删除,并将compatibleSdkVersion 字段从app 字段下迁移到当前选中的product中。当前生效的product可以通过点击编辑区域右上方
  1. 请将compatibleSdkVersiontargetSdkVersion( 若已配置)从9改为4.0.0(10),并配置runtimeOS。版本号需满足M.S.F(X)规则的字符串类型,使用英文.和()。

    "app": {
    "signingConfigs": [],
    "products": [
    {
    "name": "default",
    "signingConfig": "default",
    "compatibleSdkVersion": "4.0.0(10)", //指定HarmonyOS应用/元服务兼容的最低版本。
    "targetSdkVersion": "4.0.0(10)", //指定HarmonyOS应用/元服务目标版本。若没有设置,默认为compatibleSdkVersion
    "runtimeOS": "HarmonyOS", //指定为HarmonyOS
    }
    ],
    ...
    }

  1. 将其他各模块级别的build-profile.json5 文件中target字段下配置的runtimeOS删除。
  1. 剩下的步骤与API 10及以上的步骤相同,参考1.2.1的步骤二完成余下手动迁移步骤。

说明

  • 一键升级只针对当前选择的product生效。
  • 如有多个product,需要分别切换不同product后,按照手动升级的方式对工程进行升级。每一个product下都需要配置相应的compatibleSdkVersion和runtimeOS。
  • 针对API 8/9 NPM工程,请先按照适配OHPM包管理完成升级,再按照API 9历史工程迁移完成手动迁移配置。
  • 从DevEco Studio 4.0 Release版本开始,代码编辑器及编译构建过程增强了对ArkTS语法规范的检查,如果历史工程中存在不符合ArkTS语法规范的代码,在迁移完成后可能会报错,需根据具体报错信息修正不符合ArkTS语法规范的代码。
  • 如果历史工程包含低代码方式开发的界面,在迁移完成后,需要将这部分低代码开发的界面转换为ArkTS代码,并修正相关报错后才可以正常编译。代码转换操作会删除visual文件及其父目录,且为不可逆过程,代码转换后不能通过ets文件反向生成visual文件。

感谢各位大佬支持!!!

互三啦!!!

相关推荐
钛态11 小时前
Flutter 组件 ews 的适配 鸿蒙Harmony 实战 - 深度对接企业级 Exchange 服务、实现鸿蒙端邮件与日程的高效分发及 SOAP 协议连接方案
flutter·harmonyos·鸿蒙·openharmony
亚历克斯神11 小时前
Flutter 三方库 jwt_io 的鸿蒙化适配指南 - 在鸿蒙系统上构建极致、严谨、全能的 JSON Web Token (JWT) 加解密与身份安全验证引擎
flutter·json·harmonyos
键盘鼓手苏苏11 小时前
Flutter for OpenHarmony:使用 typed_data 直击高性能底层数据操作核心
android·flutter·华为·自动化·harmonyos
加农炮手Jinx11 小时前
Flutter 组件 sse_stream 的适配 鸿蒙Harmony 深度进阶 - 驾驭高并发 Server-Sent Events 背压处理、实现鸿蒙端工业级 AI 响应流与长效链路治理方案
flutter·harmonyos·鸿蒙·openharmony·sse_stream
钛态11 小时前
Flutter 三方库 tftp 的鸿蒙化适配指南 - 实现 RFC 1350 标准的极简文件传输协议、支持端侧嵌入式设备固件更新与局域网数据交换实战
flutter·harmonyos·鸿蒙·openharmony
左手厨刀右手茼蒿11 小时前
Flutter for OpenHarmony:mailer — 基于 SMTP 的极速邮件投递服务(适配鸿蒙 HarmonyOS Next ohos)
android·flutter·华为·交互·harmonyos
雷帝木木11 小时前
Flutter 组件 metalink 的适配 鸿蒙Harmony 深度进阶 - 驾驭节点负载热力均衡、实现鸿蒙端跨域传输安全 (TLS) 与 HAP 原子化精准推送方案
flutter·harmonyos·鸿蒙·openharmony
亚历克斯神11 小时前
Flutter 三方库 eip55 的鸿蒙化适配指南 - 在鸿蒙系统上构建极致、严谨、符合 Web3 标准的以太坊地址校验与防串改引擎
flutter·web3·harmonyos
王码码203511 小时前
Flutter 三方库 soundcloud_explode_dart 的鸿蒙化适配指南 - 实现高性能的 SoundCloud 媒体内容解析、支持音频流下载与全量元数据透传
flutter·harmonyos·鸿蒙·openharmony·soundcloud_explode_dart
国医中兴11 小时前
Flutter 三方库 linalg 的鸿蒙化适配指南 - 掌控高性能线性代数、矩阵运算实战、鸿蒙级算法中枢
线性代数·flutter·harmonyos