羊蹓狼 发表于 2024-11-18 12:12:05

HarmonyOS 应用开辟之@Builder装饰器:自定义构建函数_harmony 构件函数

先自我介绍一下,小编浙江大学结业,去过华为、字节跳动等大厂,目前阿里P7
深知大多数步伐员,想要提升技能,往往是本身探索成长,但本身不成体系的自学结果低效又漫长,而且极易碰到天花板技术故步自封!
因此收集整理了一份《2024年最新HarmonyOS鸿蒙全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
https://i-blog.csdnimg.cn/blog_migrate/4f132d426860268f36d538005159c2fc.png
https://i-blog.csdnimg.cn/blog_migrate/1e210328c1ebf43f08d3b6c5f5c13b48.png
https://i-blog.csdnimg.cn/blog_migrate/c542dd6cbb7653f21312f4bc5092ee93.png
https://i-blog.csdnimg.cn/blog_migrate/5026d52faa5c5bc85d7d770781d172f1.png
https://i-blog.csdnimg.cn/blog_migrate/433243eb5e671d9c873ce6f6cee6874e.png
既有得当小白学习的零基础资料,也有得当3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上鸿蒙开辟知识点,真正体系化!
由于文件比较多,这里只是将部门目次截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会一连更新
假如你须要这些资料,可以添加V获取:vip204888 (备注鸿蒙)
https://i-blog.csdnimg.cn/blog_migrate/2bec7bfdc6a8c410e0e18cdc5c8a08d6.png
正文

MyGlobalBuilderFunction()


[*]全局的自定义构建函数可以被整个应用获取,不允许利用this和bind方法。
[*]假如不涉及组件状态变化,发起利用全局的自定义构建方法。
参数传递规则

自定义构建函数的参数传递有 按值传递 和 按引用传递 两种,均需遵守以下规则:


[*]参数的类型必须与参数声明的类型一致,不允许undefined、null和返回undefined、null的表达式。
[*]在@Builder修饰的函数内部,不允许改变参数值。
[*]@Builder内UI语法遵循 UI语法规则 。
[*]只有传入一个参数,且参数须要直接传入对象字面量才会按引用传递该参数,别的传递方式均为按值传递。
按引用传递参数

按引用传递参数时,传递的参数可为状态变量,且状态变量的改变会引起@Builder方法内的UI刷新。
class Tmp {
paramA1: string = ‘’
}
@Builder function overBuilder(params: Tmp) {
Row() {
Text(UseStateVarByReference: ${params.paramA1} )
}
}
@Entry
@Component
struct Parent {
@State label: string = ‘Hello’;
build() {
Column() {
// Pass the this.label reference to the overBuilder component when the overBuilder component is called in the Parent component.
overBuilder({ paramA1: this.label })
Button(‘Click me’).onClick(() => {
// After Click me is clicked, the UI text changes from Hello to ArkUI.
this.label = ‘ArkUI’;
})
}
}
}
按引用传递参数时,假如在@Builder方法内调用自定义组件,ArkUI提供$$作为按引用传递参数的范式。
class Tmp {
paramA1: string = ‘’
paramB1: string = ‘’
}
@Builder function overBuilder($$ : Tmp) {…}
class Tmp {
paramA1: string = ‘’
}
@Builder function overBuilder(KaTeX parse error: Can't use function '$' in math mode at position 49: …`overBuilder===$̲{.paramA1}`)
HelloComponent({message: $$.paramA1})
}
}
}
@Component
struct HelloComponent {
@Link message: string;
build() {
Row() {
Text(HelloComponent===${this.message})
}
}
}
@Entry
@Component
struct Parent {
@State label: string = ‘Hello’;
build() {
Column() {
// Pass the this.label reference to the overBuilder component when the overBuilder component is called in the Parent component.
overBuilder({paramA1: this.label})
Button(‘Click me’).onClick(() => {
// After Click me is clicked, the UI text changes from Hello to ArkUI.
this.label = ‘ArkUI’;
})
}
}
}
按值传递参数

调用@Builder装饰的函数默认按值传递。当传递的参数为状态变量时,状态变量的改变不会引起@Builder方法内的UI刷新。以是当利用状态变量的时候,保举利用 按引用传递。
@Builder function overBuilder(paramA1: string) {
Row() {
Text(UseStateVarByValue: ${paramA1} )
}
}
@Entry
@Component
struct Parent {
@State label: string = ‘Hello’;
build() {
Column() {
overBuilder(this.label)
}
}
}
为了能让大家更好的学习鸿蒙(HarmonyOS NEXT)开辟技术,这边特意整理了《鸿蒙开辟学习手册》(共计890页),希望对大家有所帮助:https://qr21.cn/FV7h05
《鸿蒙开辟学习手册》:

怎样快速入门:https://qr21.cn/FV7h05


[*]根本概念
[*]构建第一个ArkTS应用
[*]……
https://i-blog.csdnimg.cn/blog_migrate/da60b8f42181f7f9d7276a5749b952ba.png
开辟基础知识:https://qr21.cn/FV7h05


[*]应用基础知识
[*]设置文件
[*]应用数据管理
[*]应用安全管理
[*]应用隐私保护
[*]三方应用调用管控机制
[*]资源分类与访问
[*]学习ArkTS语言
[*]……
网上学习资料一大堆,但假如学到的知识不成体系,碰到题目时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
须要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注鸿蒙)
https://i-blog.csdnimg.cn/blog_migrate/cf544c0d440e124f5d3203b14481b024.png
一个人可以走的很快,但一群人才能走的更远!岂论你是正从事IT行业的老鸟或是对IT行业感爱好的新人,都欢迎参加我们的的圈子(技术交换、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
真正的技术提升。**
须要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注鸿蒙)
[外链图片转存中…(img-tmqpUYmV-1713293947085)]
一个人可以走的很快,但一群人才能走的更远!岂论你是正从事IT行业的老鸟或是对IT行业感爱好的新人,都欢迎参加我们的的圈子(技术交换、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: HarmonyOS 应用开辟之@Builder装饰器:自定义构建函数_harmony 构件函数