鸿蒙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的普遍性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/185490.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

微信小程序 slider 翻转最大和最小值

微信小程序 slider 翻转最大和最小值 场景代码示例index.wxmlindex.jsutil.js 参考资料 场景 我想使用 slider 时最左边是 10 最右是 -10。 但是想当然的直接改成<slider min"10" max"-10" step"1" /> 并没用。 查了文档和社区也没有现成…

netstat和ps命令

查看端口占用情况 netstat -apn | grep 9091 Proto Recv-Q Send-Q Local Address Foreign Address State tcp6 0 0 127.0.0.1:9091 127.0.0.1:36644 ESTABLISHED 83369/./pushgateway意思为 127.0.0.1:36644 通过进…

开会的流程和步骤:高效率的组织好一场会议的9种方法

九种让你的会议更有效的方法&#xff1a;1.明确会议目的&#xff1b;2.设计会议议程&#xff1b;3.邀请合适的人&#xff1b;4.有效开场&#xff1b;5.建立基本会议规则&#xff1b;6.把不相关的话题先搁置一边&#xff1b;7.管理参与者的行为&#xff1b;8.改进和持续跟踪&…

虚幻学习笔记4—文本内容处理

一、前言 本文使用的虚幻引擎5.3.2&#xff0c;在虚幻中已经集成了很多可以直接处理多样化文本的蓝图&#xff0c;比如格式化动态显示、浮点数多样化等。 二、实现 2.1、格式化文本显示动态内容&#xff1a;在设置某个文本时可以使用“Format Text”蓝图设置自定义可以的显示…

建立ISO 27001,能给企业带来哪些好处?

在当今信息时代&#xff0c;企业面临着越来越多的信息安全挑战。为了应对这些挑战&#xff0c;许多企业开始寻求ISO27001信息安全管理体系标准的帮助。本文将详细解答ISO27001建立后能给企业带来哪些好处&#xff0c;并为您详解ISO27001标准及其认证过程。 1. 提升企业信息安全…

Django 模板引擎 (四)

一、Django模板引擎 一个强大的工具&#xff0c;用于在HTML页面中嵌入动态内容。它使用一种被称为Django模板语言&#xff08;Django Template Language&#xff09;的简单而强大的语法来处理模板。该模板语言使用”{% %}”进行标记&#xff0c;用于执行各种操作。 二、Django…

【论文精读】HuggingGPT: Solving AI Tasks with ChatGPT and its Friends in Hugging Face

HuggingGPT: Solving AI Tasks with ChatGPT and its Friends in Hugging Face 前言Abstract1 Introduction2 Related Works3 HuggingGPT3.1 Task PlanningSpecification-based InstructionDemonstration-based Parsing 3.2 Model SelectionIn-context Task-model Assignment 3…

测试需要写测试用例吗?(从不同角度下剖析问题)

前言 最近在网上看到关于这样的一个话题“测试需要写测试用例吗&#xff1f;”&#xff0c;引起了很多同学的讨论。这段话是这样的&#xff1a; 测试用例主要作用&#xff1a;有效地评估软件的质量&#xff0c;测试用例质量体现了测试的质量。 下面摘取一部分同学的观点&…

如何理解程序之间的解耦和元注解的应用?

1.如何理解程序之间的解耦&#xff1f; 我的理解是解耦是将有联系的代码或者有依赖的代码之间 通过中间的方式去处理而不是写成固定的方式&#xff0c;而是通过统一的定义的某种方式去结合这些依赖关系&#xff0c;比如使用反射机制 2.解耦是将代码之间的依赖关系降低到最小&…

记录labelImg上手过程

一、安装 Labelimg&#xff08;目标检测标注工具&#xff09;安装_labelimg安装_向南不向北的博客-CSDN博客 二、打开 进入anaconda虚拟环境后&#xff0c;cd到labelimg文件夹&#xff0c;然后输入命令 python labelImg.py 三、基础设置 打标工具labelimg安装和使用教程-C…

【知识】稀疏矩阵是否比密集矩阵更高效?

转载请注明出处&#xff1a;小锋学长生活大爆炸[xfxuezhang.cn] 问题提出 有些地方说&#xff0c;稀疏图比密集图的计算效率更高&#xff0c;真的吗&#xff1f; 原因猜想 这里的效率高&#xff0c;应该是有前提的&#xff1a;当使用稀疏矩阵的存储格式(如CSR)时&#xff0c;计…

【2019年数据结构真题】

【2019统考真题】设线性表L (a1&#xff0c;a2&#xff0c;a3&#xff0c;…&#xff0c;an-2&#xff0c;an-1&#xff0c;an)采用带头结点的单链表保存&#xff0c;链表中的结点定义如下&#xff1a; typedef struct node{int data;struct node*next; }NODE;请设计一个空间复…

酷狗音乐app 评论signature

文章目录 声明目标加密参数定位翻页逻辑代码实现 声明 本文章中所有内容仅供学习交流&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由此产生的一切后果均与作者无关&#xff0c;若有侵权&#xff0c;请私信我立即删除&#xff01; 目标 复制curl转python # -*- c…

供应链大事记 | 2024第二届中国供应链碳中和峰会来了!

背景 当下&#xff0c;全球气候变化、环境污染、资源紧张问题加剧&#xff0c;世界各国致力于推动碳达峰、碳中和&#xff0c;绿色低碳发展已成为全球共识。我国也于2020年明确提出“3060双碳目标”&#xff0c;经济结构、能源结构、产业结构亟待转型升级&#xff0c;各重点行…

熟悉SVN基本操作-(SVN相关介绍使用以及冲突解决)

一、SVN相关介绍 1、SVN是什么? 代码版本管理工具它能记住你每次的修改查看所有的修改记录恢复到任何历史版本恢复已经删除的文件 2、SVN跟Git比&#xff0c;有什么优势 使用简单&#xff0c;上手快目录级权限控制&#xff0c;企业安全必备子目录checkout&#xff0c;减少…

体脂称方案设计——电子秤方案芯片CS1231

电子秤与我们日常生活息息相关&#xff0c;智能科技化的生活形成万物互联的模式。测量精度领域随着大市场的发展也进入到发展高峰时期&#xff0c;电子秤从开始的弹簧压力测物体重量走向更为智能的测体脂、人体成分等相关的测量。所以在做方案开发中它的功能也在更新和智能化。…

Git——工作区管理

如何管理工作目录&#xff0c;以便用户可以更高效地新建提交。如何在处理工作区和暂存区文件的过程中修复错误&#xff0c;以及如何修复最近一次提交记录中的问题&#xff1b;同时还会了解到如何安全地使用暂存机制和多个工作目录处理工作流中的中断问题。 主要内容有以下几点…

玻色量子研发进展

2023年 2023.8 量子计算突破云渲染资源调度&#xff01;真机测试完整报告公开&#xff01; 2023.8 量子计算突破金融信用评分&#xff01;真机测试完整报告公开&#xff01; 2023.7 玻色量子“揭秘”之旅行商问题与Ising建模 2023.7 玻色量子“揭秘”之背包问题与Ising建…

Ubuntu 配置打开文件限制

cat /etc/security/limits.conf | grep -Ev "^$|#"量 # ulimit -n 1024000软限制的打开文件数 # ulimit -Sn 1024000硬限制的打开文件数量 # ulimit -Hn 1024000系统打开文件描述符的最大数量 # sysctl fs.nr_open fs.nr_open 1048576系统打开文件的最大数量 #…

采集软件大全-全网免费的采集软件大全

采集软件大揭秘&#xff1a;从排名到任意网站采集的全方位解读 在数字时代&#xff0c;信息是黄金&#xff0c;而采集软件就是那把能够淘金的工具。无论是市场调研、竞品分析还是SEO优化&#xff0c;采集软件都扮演着不可或缺的角色。在这个领域里&#xff0c;有许多选择&…