鸿蒙4.0开发笔记之ArkTS装饰器语法基础@Builder组件内自定义构建函数与@Styles自定义组件重用样式(十)

本文主要是介绍鸿蒙4.0开发笔记之ArkTS装饰器语法基础@Builder组件内自定义构建函数与@Styles自定义组件重用样式(十),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 一、@Builder自定义构建函数
      • 1、什么是自定义构建函数
      • 2、组件内定义构建函数
      • 3、组件外定义构建函数
      • 4、@Builder装饰器练习
    • 二、@Styles重用样式函数
      • 1、重用样式的作用
      • 2、组件内定义@Styles
      • 3、组件外定义
      • 4、@Styles装饰器练习
      • 5、注意要点

一、@Builder自定义构建函数

1、什么是自定义构建函数

ArkUI还提供了⼀种更轻量的UI元素复用机制 @Builder , @Builder 所装饰的函数遵循
build() 函数语法规则,开发者可以将重复使用的UI元素抽象成⼀个方法,在build方法里调用。

2、组件内定义构建函数

(1)定义语法:@Builder MyBuilder(...) {...}
(2)使用语法:this.MyBuilder(...) {...}
(3)语法要点:

  • 自定义构建函数可以在所属组件的 build方法和其他自定义构建函数中调用,但不允许在组件外调用。
  • 允许在自定义组件内定义⼀个或多个 @Builder方法,该方法被认为是该组件的私有、特殊类型的成员函数。
  • 在自定义函数体中,this指代当前所属组件,组件的状态变量可以在自定义构建函数内访问。建议通过this访问自定义组件的状态变量而不是参数传递。
  • 自定义组件不仅可以添加属性,还可以添加事件
    (4)参数传递规则
    4、参数传递规则
    自定义构建函数的参数传递有按值传递和按引用传递两种,均需遵守以下规则:

参数的类型必须与参数声明的类型一致,不允许undefined、null和返回undefined、null的表达式。
在自定义构建函数内部,不允许改变参数值。如果需要改变参数值,且同步回调用点,建议使用@Link。
@Builder内UI语法遵循官方文档:自定义组件语法规则。

3、组件外定义构建函数

组件外定义构建函数的优点是方便多组件共同调用。定义时,需要加上function关键字。

//在组件外定义words构建函数
@Builder function words2(content:string){...}
//使用组件外定义的构建函数:不能使用this或bind方法
words2(content)

4、@Builder装饰器练习

(1)练习任务
定义一个被@Builder修饰的构建函数,要求能够在同一行显示图标和文本。使用状态值刷新属性,点击时图标和文本发生相应的变化;刷新动作,再次点击后能够恢复原来的状态。

(2)练习代码

@Entry
@Component
struct Index {@State message: string = '@Builder \n 组件内构建函数'//设置状态变量,方便在选中诗词时能够作为标志位,默认未选中@State isChoose: boolean = false//创建组件内的构建函数:可以设定传递参数content@Builder words(content:string){Row(){Image(this.isChoose ? $r('app.media.icon') : $r('app.media.ic')).width(35).margin(15)//构建函数调用自己的形式参数时不需要使用this引用Text(content).fontSize(25).decoration({type:this.isChoose ? TextDecorationType.LineThrough : TextDecorationType.None})}.backgroundColor(Color.Orange).padding(5).borderRadius(25).width('85%').height(70).margin({top:10})//给row组件加上点击事件.onClick(()=>{this.isChoose = !this.isChoose})}build() {Row() {Column({space:20}) {Text(this.message).fontSize(50).fontWeight(FontWeight.Bold).textAlign(TextAlign.Center)  //设置文本居中显示//在组件内调用组件内定义的构建函数:由于该构建函数属于组件内的一部分,因此需要使用this进行调用this.words('是造物者之无尽藏也,')this.words('而吾与子之所共适!')//调用组件外构建函数// words2('是造物者之无尽藏也,')// words2('而吾与子之所共适!')}.width('100%')}.height('100%')}
}//创建组件外构建函数:必须加上关键字function
@Builder function words2(content:string){Row(){Image(this.isChoose ? $r('app.media.icon') : $r('app.media.ic')).width(35).margin(15)//构建函数调用自己的形式参数时不需要使用this引用Text(content).fontSize(25).decoration({type:this.isChoose ? TextDecorationType.LineThrough : TextDecorationType.None})}.backgroundColor(Color.Pink).padding(5).borderRadius(25).width('85%').height(70).margin({top:10})//给row组件加上点击事件.onClick(()=>{this.isChoose = !this.isChoose})
}

(3)练习效果
1.3.1
1.3.2

二、@Styles重用样式函数

1、重用样式的作用

就是为了提高开发效率,因为如果每个组件的样式都需要单独设置,在开发过程中会出现大量代码在进行重复样式设置,虽然可以复制粘贴,但为了代码简洁性差,并且后期不方便维护,因此需要使用重用样式装饰器@Styles来定义公用样式。

@Styles装饰器可以将多条样式设置提炼成⼀个方法,直接在组件声明的位置调用。通过@Styles装饰器可以快速定义并复用自定义样式。用于快速定义并复用自定义样式。

2、组件内定义@Styles

定义在组件内的@Styles可以通过this访问组件的常量和状态变量,并可以在@Styles⾥通过事件来改变状态变量的值,示例如下:

//定义样式:直接定义,不可传参
@Styles conmmonStyle(){//样式函数中可以只写样式.width(200).height(80).backgroundColor(Color.Orange)}//调用通用样式Image($r('app.media.icon')).conmmonStyle()

3、组件外定义

在全局定义时需在方法名前⾯添加function关键字,组件内定义时则不需要添加function关键字。

//定义样式:必须加上function,不可传参
@Styles function conmmonStyle2(){//样式函数中可以只写样式.width(200).height(80).backgroundColor(Color.Pink)
}
//调用通用样式
Image($r('app.media.icon')).conmmonStyle2()

4、@Styles装饰器练习

(1)练习任务
创建一个通用样式,定义宽、高、背景颜色这三个通用的样式,再将创建的ConmmonStyle应用在图片、按钮、行组件和文本组件上。

(2)练习代码

@Entry
@Component
struct Index {@State message: string = '@Styles重用样式'//创建通用样式函数:与正常组件内的函数定义一致@Styles conmmonStyle(){//样式函数中可以只写样式.width(200).height(80).backgroundColor(Color.Orange)}build() {Row() {Column({space:20}) {Text(this.message).fontSize(40).fontWeight(FontWeight.Bold)//调用组件内定义的样式函数//虽然被@Styles修饰了且处于组件内定义,但调用样式函数时却不需要thisImage($r('app.media.icon')).conmmonStyle()Button('按钮').conmmonStyle()Row(){}.conmmonStyle()Text('文本框').conmmonStyle()//调用组件外定义的样式函数//Image($r('app.media.icon')).conmmonStyle2()//Button('按钮').conmmonStyle2()//Row(){}.conmmonStyle2()//Text('文本框').conmmonStyle2()}.width('100%')}.height('100%')}
}//注意:两个同名样式函数在组件内部和外部同时存在时,内部样式的优先级更高//创建通用样式函数:必须加上function
@Styles function conmmonStyle2(){//样式函数中可以只写样式.width(200).height(80).backgroundColor(Color.Pink)
}

(3)测试效果
2.4.1

5、注意要点

只能写通用的、固定的样式函数,需要具有普遍性,因此在定义时的样式属性有限。

不能传递参数,由于是样式函数,通过链式直接调用样式时不能够传递参数,这也同样对应@Styles的普遍性。

这篇关于鸿蒙4.0开发笔记之ArkTS装饰器语法基础@Builder组件内自定义构建函数与@Styles自定义组件重用样式(十)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/435362

相关文章

Kotlin 作用域函数apply、let、run、with、also使用指南

《Kotlin作用域函数apply、let、run、with、also使用指南》在Kotlin开发中,作用域函数(ScopeFunctions)是一组能让代码更简洁、更函数式的高阶函数,本文将... 目录一、引言:为什么需要作用域函数?二、作用域函China编程数详解1. apply:对象配置的 “流式构建器”最

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定

一文详解如何从零构建Spring Boot Starter并实现整合

《一文详解如何从零构建SpringBootStarter并实现整合》SpringBoot是一个开源的Java基础框架,用于创建独立、生产级的基于Spring框架的应用程序,:本文主要介绍如何从... 目录一、Spring Boot Starter的核心价值二、Starter项目创建全流程2.1 项目初始化(

使用Java实现通用树形结构构建工具类

《使用Java实现通用树形结构构建工具类》这篇文章主要为大家详细介绍了如何使用Java实现通用树形结构构建工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录完整代码一、设计思想与核心功能二、核心实现原理1. 数据结构准备阶段2. 循环依赖检测算法3. 树形结构构建4. 搜索子

C#基础之委托详解(Delegate)

《C#基础之委托详解(Delegate)》:本文主要介绍C#基础之委托(Delegate),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 委托定义2. 委托实例化3. 多播委托(Multicast Delegates)4. 委托的用途事件处理回调函数LINQ

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda