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

embedded/2025/3/19 15:42:54/

目录

1 -> 一体化工程迁移

1.1 -> 自动迁移

1.2 -> 手动迁移

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

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,进入迁移助手页面。

2. 在页面下方的Migrate Assistant页签中选择迁移到5.0.0/5.0.1/5.0.2,并点击Migrate按钮,此时将出现弹窗提示开发者进行数据备份。若确认已完成备份,请点击弹窗中Migrate,启动迁移任务。

3. 待工程重新完成同步,并无其他报错提示,即为迁移成功。

说明

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

1.2 -> 手动迁移

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

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

1. 进入工程级build-profile.json5文件,删除compileSdkVersion配置。若工程为Openharmony工程,则无需删除compileSdkVersion字段。

2. 删除并修改Hvigor相关文件:

  • 在左侧工程目录中删除hvigorw、hvigorw.bat文件,并删除hvigor目录下的hvigor-wrapper.js文件。

  • 进入hvigor > hvigor-config.json5文件中,新增modelVersion字段,以API 12为例,其值为"5.0.0"。并删除hvigorVersion字段、dependencies中的@ohos/hvigor-ohos-pluginrollup字段

3. 在工程级oh-package.json5文件中同样也需新增modelVersion字段,以API 12为例,其值为"5.0.0"。

4. 在local.properties文件中,删除HarmonyOS SDK配置。若工程为Openharmony工程,则无需执行此步骤。

5. 点击编辑界面上方Sync now或进入菜单栏点击File > Sync and Refresh Project,重新进行工程同步。若无其他报错,至此历史工程手动迁移完成。

1.2.2 -> API 9历史工程迁移

1. 将工程级build-profile.json5文件中compileSdkVersion字段删除,并将compatibleSdkVersion字段从app字段下迁移到当前选中的product中。当前生效的product可以通过点击编辑区域右上方

2. 请将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}],...
}

3. 将其他各模块级别的build-profile.json5文件中target字段下配置的runtimeOS删除。

4. 剩下的步骤与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文件。

感谢各位大佬支持!!!

互三啦!!!


http://www.ppmy.cn/embedded/173896.html

相关文章

WebRTC中音视频服务质量QoS之RTT衡量网络往返时延的加权平均RTT计算机制‌详解

WebRTC中音视频服务质量QoS之RTT衡量网络往返时延加权平均RTT计算机制‌的详解 WebRTC中音视频服务质量QoS之RTT衡量网络往返时延加权平均RTT计算机制‌的详解 WebRTC中音视频服务质量QoS之RTT衡量网络往返时延加权平均RTT计算机制‌的详解前言一、 RTT 网络往返时延的原理‌1、…

顺序表的C语言实现与解析

目录 引言 作者主页:共享家9527-CSDN博客 ​编辑代码结构概览 头文件( ST.h )要点 源文件要点 1. 顺序表初始化( SeqListInit ): 2. 顺序表销毁( SeqListDestroy )&…

蓝桥杯练习day1:拆分数位-四位数字的最小和

前言 给你一个四位 正 整数 num 。请你使用 num 中的 数位 ,将 num 拆成两个新的整数 new1 和 new2 。new1 和 new2 中可以有 前导 0 ,且 num 中 所有 数位都必须使用。 比方说,给你 num 2932 ,你拥有的数位包括:两…

【数据结构】顺序表和链表

一、线性表 线性表是n个具有相同特性的数据元素的有限序列。线性表是一种在实际中广泛使用的数据结构,常见的线性表有:顺序表,链表,栈,队列,字符串 线性表在逻辑上是线性结构,也就是说是连续的…

【CSS】一、基础选择器

文章目录 1、CSS2、CSS的引入方式3、选择器3.1 标签选择器3.2 类选择器3.3 id选择器3.4 通配符选择器 4、练习:画盒子 1、CSS CSS,Cascading Style Sheets,层叠样式表,是一种样式表语言,用于表述HTML的呈现&#xff0…

组合Composition(has-a)

在 Python 中,**组合(Composition)** 是一种设计模式,用于将一个类的实例作为另一个类的属性。这种模式允许你将多个类的功能组合在一起,而不是通过继承来实现。组合强调的是“有一个”(has-a)关…

桌子(table、desk)以及其他常见物体的urdf模型,用于搭建机器人环境如pybullet、Gazebo

一、背景 我们在搭建仿自己的仿真环境时,需要添加一些物品,如桌子,托盘等,使得我们的场景更丰富并贴合我们的任务。但手写这些常见物品的urdf是不现实的,所以下面给出了github上开源的模型,感谢开源。 我…

如何让焦虑为城市供能 | 杂谈

凌晨两点,我盯着满桌冷掉的碳烤磷虾烩面——这顿价值500星币的宵夜。当冒充食客的就餐员像幽灵般消失后,躁动的神经末梢突然刺破迷雾:那些令人窒息的负能量,是否能在量子层面转化为清洁动能? 这个疯狂假设打开了四维能…