HarmonyOS开发实战指南:ArkTS/TS代码重构

46 篇文章 0 订阅
46 篇文章 0 订阅

 Refactor-Extract代码提取

在编辑器中支持将函数内、类方法内等区域代码块或表达式,提取为新方法/函数(Method)、常量(Constant)、接口(Interface)、变量(Variable)或类型别名(Type Alias)。准确便捷的将所选区域代码从当前作用域内进行提取,提升编码效率。选中所需要提取的代码块,右键单击Refactor,选择需要提取的类型。

说明

Refactor-Extract代码提取为类型别名(Type Alias)能力仅TS语言支持。

方法/函数(Method)支持选中代码块或完整语句进行提取:

在ArkTS语言中,支持将组件调用代码块提取为@Builder装饰器装饰的方法,组件属性调用表达式可提取为@Styles或@Extend装饰器装饰的方法。

使用方式:选中需要提取的组件或属性,右键单击Refactor,选择Extract Method...,组件私有属性可提取为@Extend装饰的方法,通用属性可提取为@Styles或@Extend装饰的方法。

常量(Constant)支持选中单行表达式进行提取:

接口(Interface)支持选中对象自变量进行提取:

支持选中表达式提取为变量(Variable):

Refactor-Covert代码转换

编辑器内提供Convert重构能力,支持Convert between named imports and namespace imports等高频转换操作,辅助开发者高效重构代码,提升代码质量。可以在菜单栏进入File > Settings... > Editor > Intentions,点击JavaScript选项,可以查看convert相关功能的介绍及转换前后对比效果。

表1 Refactor-Covert功能支持清单

功能

说明

使用方法

支持转换的源码类型

Convert to class

将JS源码中的function转换为符合ES6标准的类

点击或选中function名,点击灯泡图标,在下拉菜单中选择Convert to class

说明

若当前工程中已引用该方法,执行Convert to class后,在Find Usages中可查看引用的具体位置,点击Do Refactor可忽略冲突并执行转换;也可以逐条修改引用位置的代码后,重新执行Convert to class

JS

Convert to anonymous function

将箭头函数转换为匿名函数

选中箭头函数赋值变量,点击灯泡图标,在下拉菜单中选择Convert to anonymous function

JS/TS

Convert to named function

将箭头函数转换为普通函数

选中箭头函数赋值变量,点击灯泡图标,在下拉菜单中选择Convert to named function

JS/TS/ArkTS

Convert to arrow function

将匿名函数转换为箭头函数

选中匿名函数赋值变量,点击灯泡图标,在下拉菜单中选择Convert to arrow function

JS/TS/ArkTS

Convert default export to named export

支持named export和default export相互转换

完整选中export default语句,点击灯泡图标,在下拉菜单中选择Convert default export to named export

JS/TS/ArkTS

Convert named export to default export

完整选中export语句,点击灯泡图标,在下拉菜单中选择Convert named export to default export

Convert named imports to namespace import

支持在命名import和命名空间import形态间转换

完整选中import语句,点击灯泡图标,在下拉菜单中选择Convert named imports to namespace import

JS/TS/ArkTS

Convert namespace import to named imports

完整选中命名空间import语句,点击灯泡图标,在下拉菜单中选择Convert namespace import to named imports

Convert to template string

将字符串转换为模板字面量

选中字符串或完整表达式,点击灯泡图标,在下拉菜单中选择Convert to template string

JS/TS/ArkTS

Convert to optional chain expression

将判空逻辑转换为可选链式调用

选中连续判空表达式,点击灯泡图标,在下拉菜单中选择Convert to optional chain expression

JS/TS/ArkTS

Refactor-Rename代码重命名

代码编辑支持Rename功能,可以快速更改变量、方法、对象属性等相关标识符及文件、模块的名称,并同步到整个工程中对其进行引用的位置。

使用方式:选中需要重新命名的标识符(变量、类、接口、自定义组件等),右键单击Refactor,选择Rename...(或使用快捷键Shift+F6),在弹框中输入新的标识符名称,并在Scope中选择替换的范围,点击Refactor完成重新命名。

代码编辑支持筛选并过滤不需要rename的引用位置。在Rename...弹窗中点击Preview,在弹出预览窗口中,用户选中无需Rename的选项,单击右键菜单Exclude/Remove进行过滤/删除,完成筛选后点击左下角Do Refactor,重新执行Rename操作。

说明

若ArkTS文件中存在C++接口调用,使用Rename进行重命名时,C++文件中涉及的函数名也会被重命名。

Move File

在文件中单击右键,选择Refactor > Move File...,在弹窗中输入或点击...选择指定的目录,点击Refactor,可将当前文件移动至该目录下。勾选Search for references,可查找并更新工程中对该文件的引用;勾选Open in editor,可在编辑器中查看移动的文件。

Safe Delete

编辑器支持Safe Delete功能,帮助您安全地删除代码中的标识符对象(变量、函数或类等)或删除指定文件。在删除前,编辑器将先在代码中搜索对该对象的引用,如果存在引用,编辑器将提示您进行必要的检查和调整。

使用方式:在编辑器内选中需要删除的标识符对象或在工程目录选择待删除的文件,右键单击Refactor,选择Safe Delete,单击OK将自动检查当前对象在代码中被引用的情况,点击View Usages可查看具体使用的代码内容,点击Delete Anyway将直接删除该对象的定义。

C++代码重构

编辑器提供C++代码重构能力,当前支持展开宏、交换if分支、移动函数体到声明处等使用场景下的重构能力,提升开发效率。

展开宏

支持在当前宏引用处展开宏。将光标移动至需要展开的宏,右键单击Refactor > Inline,展开此处引用的宏。

交换if分支

编辑器支持在选中if-else完整代码块的情况下,实现对if-else代码块的位置交换,并对条件取反。

使用约束

  • 需要重构的代码块必须为完整的if-else代码结构,{}不能省略;
  • if-else中的statement包含嵌套if-else语句时,只反转最外层的if-else语句。对于if() -else if()-else() 结构,仅支持对最后一层if-else结构进行交换;
  • 不支持赋值语句的判断条件取反。

使用方式

编辑器内选择需要转换的代码区域,右键单击Refactor,选择Swap If Branches,对原有if条件取反,并交换if-else原代码块顺序。

移动函数体到声明处

编辑器支持将函数体从源文件移动到头文件中,提高代码可读性。编辑器内选中函数名,右键单击Refactor,选择Move to Declaration,源文件中的函数实现将移动至头文件中。

移动函数体到实现处

在编辑器内将光标放在或选中函数名,右键单击Refactor,选择Move to Implementation,选择移动到的文件,将函数定义移动到该文件。

将语句转为原始字符串

编辑器提供重构能力,支持将带有 \n, \t, \", \\, \'五类转义字符的字符串转换为原始字符串。当前仅支持标准字符串,不支持 u8""等其他字符串。

在编辑器内选择字符串代码区域,右键单击Refactor,选择Convert To Raw String,将语句转换为原始字符串。

定义构造函数

编辑器提供重构能力,支持为类的成员变量生成默认的构造函数。

规格限制

  1. 不支持未初始化成员变量的类
  2. 不支持在(class标志符,类名,大括号)以外的位置触发
  3. 不支持类已存在有入参的构造函数

使用方法:在类的定义的类名处,右键单击Generate...,选择Constructor,在弹框中点击Define,为成员变量定义一个构造函数。

提取表达式到变量

在编辑器内,选中需要提取的表达式范围,右键单击Refactor,选择Extract Variable,支持提取表达式到变量。

移除namespace

光标停留在需要移除的namespace处,右键单击Refactor,选择Remove Using Namespace进行移除,可以避免命名冲突,提高代码可读性。

添加using声明

编辑器内,光标停留在需要添加using声明处,右键单击Refactor,选择Add Using完成使用using定义类型别名。

auto自动展开

在auto关键字处右键单击Refactor,选择Expand Auto Type,可以使用推断类型替换auto类型。

声明隐式成员

编辑器支持在类中声明隐式复制/移动成员。光标停留在需要生成的类处,右键单击Generate..., 选择Copy/Move Members

最后

有很多小伙伴不知道学习哪些鸿蒙开发技术?不知道需要重点掌握哪些鸿蒙应用开发知识点?但是又不知道从哪里下手,而且学习时频繁踩坑,最终浪费大量时间。所以本人整理了一些比较合适的鸿蒙(HarmonyOS NEXT)学习路径和一些资料的整理供小伙伴学习

点击领取→纯血鸿蒙Next全套最新学习资料希望这一份鸿蒙学习资料能够给大家带来帮助,有需要的小伙伴自行领取~~

一、鸿蒙(HarmonyOS NEXT)最新学习路线

​​

有了路线图,怎么能没有学习资料呢,小编也准备了一份联合鸿蒙官方发布笔记整理收纳的一套系统性的鸿蒙(OpenHarmony )学习手册(共计1236页)与鸿蒙(OpenHarmony )开发入门教学视频,内容包含:(ArkTS、ArkUI开发组件、Stage模型、多端部署、分布式应用开发、音频、视频、WebGL、OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、Harmony南向开发、鸿蒙项目实战等等)鸿蒙(HarmonyOS NEXT)…等技术知识点。

获取以上完整版高清,请点击→纯血版全套鸿蒙HarmonyOS学习资料

二、HarmonyOS Next 最新全套视频教程

​​

三、《鸿蒙 (OpenHarmony)开发基础到实战手册》

OpenHarmony北向、南向开发环境搭建

​​

四、大厂面试必问面试题

​​

五、鸿蒙南向开发技术

​​

六、鸿蒙APP开发必备

​​
完整鸿蒙HarmonyOS学习资料,请点击→纯血版全套鸿蒙HarmonyOS学习资料

总结
总的来说,对于大家来说ye是一个挑战,也是一个机会。只有积极应对变化,不断学习和提升自己,他们才能在这个变革的时代中立于不败之地。 

                        

  • 31
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值