HarmonyOS鸿蒙学习笔记(22)@Builder实战

@Builder标签是一种更轻量的UI元素复用机制,下面通过一个简单的例子来具体说明:
比如如下布局效果:上面是一个轮播的Swiper,下面是一个Grid
在这里插入图片描述
布局代码如下:

build() {Navigation() {Scroll() {Column({ space: CommonConstants.COMMON_SPACE }) {//构建SwiperSwiper(this.swiperController) {ForEach(WindowViewModel.getSwiperImages(), (img: Resource, index?: number) => {Image(img).borderRadius($r('app.float.home_swiper_border_radius'))}, (img: Resource, index?: number) => index + JSON.stringify(img.id))}.margin({top: $r('app.float.home_swiper_margin')}).autoPlay(true)//构建GridGrid() {ForEach(WindowViewModel.getFirstGridData(), (firstItem: ItemData, index?: number) => {GridItem() {Column() {Image(firstItem.image).width($r('app.float.home_home_cell_size')).height($r('app.float.home_home_cell_size'))Text(firstItem.title).fontSize($r('app.float.little_text_size')).margin({ top: $r('app.float.home_home_cell_margin') })}}}, (firstItem: ItemData, index?: number) => index + JSON.stringify(firstItem))}.columnsTemplate(CommonConstants.GRID_FOUR_COLUMNS).rowsTemplate(CommonConstants.GRID_TWO_ROWS).columnsGap($r('app.float.home_grid_columns_gap')).rowsGap($r('app.float.home_grid_row_gap')).padding({top: $r('app.float.home_grid_padding'),bottom: $r('app.float.home_grid_padding')}).height($r('app.float.home_grid_height')).backgroundColor(Color.White).borderRadius($r('app.float.background_border_radius'))}}.scrollBar(BarState.Off).margin({left: $r('app.float.home_padding'),right: $r('app.float.home_padding')})}.title(this.NavigationTitle()).titleMode(NavigationTitleMode.Mini).hideBackButton(true).backgroundColor($r('app.color.background'))}

可以发现布局代码臃肿不易读,此时可以通过@Builder来讲上面的代码进行精简:修改后的布局,将上面的SwiperGrid分别使用@Builder组件剥离出两个方法buildSwiper和buildGrid显得更简洁易读:

 @BuilderbuildSwiper(){Swiper(this.swiperController) {ForEach(WindowViewModel.getSwiperImages(), (img: Resource, index?: number) => {Image(img).borderRadius($r('app.float.home_swiper_border_radius'))}, (img: Resource, index?: number) => index + JSON.stringify(img.id))}.margin({top: $r('app.float.home_swiper_margin')}).autoPlay(true)}@BuilderbuildGrid(){Grid() {ForEach(WindowViewModel.getFirstGridData(), (firstItem: ItemData, index?: number) => {GridItem() {Column() {Image(firstItem.image).width($r('app.float.home_home_cell_size')).height($r('app.float.home_home_cell_size'))Text(firstItem.title).fontSize($r('app.float.little_text_size')).margin({ top: $r('app.float.home_home_cell_margin') })}}}, (firstItem: ItemData, index?: number) => index + JSON.stringify(firstItem))}.columnsTemplate(CommonConstants.GRID_FOUR_COLUMNS).rowsTemplate(CommonConstants.GRID_TWO_ROWS).columnsGap($r('app.float.home_grid_columns_gap')).rowsGap($r('app.float.home_grid_row_gap')).padding({top: $r('app.float.home_grid_padding'),bottom: $r('app.float.home_grid_padding')}).height($r('app.float.home_grid_height')).backgroundColor(Color.White).borderRadius($r('app.float.background_border_radius'))}build() {Navigation() {Scroll() {Column({ space: CommonConstants.COMMON_SPACE }) {this.buildSwiper()this.buildGrid()}}.scrollBar(BarState.Off).margin({left: $r('app.float.home_padding'),right: $r('app.float.home_padding')})}.title(this.NavigationTitle()).titleMode(NavigationTitleMode.Mini).hideBackButton(true).backgroundColor($r('app.color.background'))}

在这里插入图片描述

这里只是简单的介绍了其初级用法,更多复杂的用法参考官方文档

参考资料:
@Builder装饰器:自定义构建函数
源代码地址

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

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

相关文章

测试老司机聊聊测试设计都包含什么?

一、数据组合测试设计 数据组合测试设计(Combinatorial Test Design,CTD)是一种优化测试用例的方法,它通过系统地组合不同的测试数据输入,以确保全面覆盖各种可能的测试情况。这种方法主要应用于软件测试领域&#xff…

性能优化-HVX 开发环境介绍

「发表于知乎专栏《移动端算法优化》」 本篇以 HVX 的开发环境配置以及应用实例编译测试为主进行讲述。 🎬个人简介:一个全栈工程师的升级之路! 📋个人专栏:高性能(HPC)开发基础教程 &#x1f3…

scanf解决遇到空格停止问题

scanf解决遇到空格停止问题 gets修改scanf的停止符 我们经常输入字符串的时候,遇到空格,scanf就会停止: 比如这时候我想输入一个句子:“My Love”: char* s (char*)malloc(sizeof(char)*100);scanf("%s", s…

摄像头电机马达驱动芯片LV8548/LV8549/ONSEMI替代料GC8548

摄像头电机马达驱动芯片GC8548,兼容替代 ON的LV8548 无需更改外围 . 下图为其参数分析: GC8548 是一款双通道 12V 直流电机驱动芯片,为摄像机、消费类产品、玩具和其他低压或者电池供电的运动控制类应用提供了集成的电机驱动解决方案。芯片…

hpa自动伸缩

1、定义:hpa全称horizontal pod autoscaling(pod的水平自动伸缩),这是k8s自带的模块。pod占用CPU的比率到达一定阀值会触发伸缩机制(根据CPU使用率自动伸缩) replication controller副本控制器&#xff0c…

带头 + 双向 + 循环链表增删查改实现

目录 源码: List.c文件: List.h文件: 简单的测试: 很简单,没什么好说的,直接上源码。 源码: List.c文件: #include"DLList.h"ListNode* creadNode(LTDataType x) {L…

力扣!30天60道(第2天)

第1题(1.22) &#xff1a;两数之和 解法一&#xff1a;暴力破解 #include <iostream> #include <vector> #include <map> using namespace std;class Solution { public:vector<int> twoSum1(vector<int>& nums, int target) {for (int i …

Java项目:基于ssm框架实现的电影评论系统(ssm+B/S架构+源码+数据库+毕业论文)

一、项目简介 本项目是一套ssm826基于ssm框架实现的电影评论系统&#xff0c;主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的Java学习者。 包含&#xff1a;项目源码、数据库脚本等&#xff0c;该项目附带全部源码可作为毕设使用。 项目都经过严格调试&#x…

grpcui安装使用

官网地址&#xff1a;https://github.com/fullstorydev/grpcui 安装命令&#xff1a; go get github.com/fullstorydev/grpcui go install github.com/fullstorydev/grpcui/cmd/grpcui ./bin/grpcui --import-path/home/xx/proto -proto xx.proto --plaintext 10.2.9.112:1…

GEE脚本——GEE中如何查询历史脚本和防丢失记录

很多时候我们会发现我们之前编辑的脚本不见了,本来已经编辑好了但是发现原来的脚本更完美,至于诸如此类的一些问题,当我们在使用GEE中的代码编译器的时候会时不时的出现,这里我们也无需过多担心,这里只要你首次将代码保存在你所创建的项目当中的时候我们就可以查看以往每一…

【爬虫、数据可视化实战】以“人口”话题为例爬取实时微博数据并进行舆情分析

前言&#xff1a; 近期在weibo上讨论的比较热的话题无非就是“人口”了。TaoTao也看了一些大家发的内容。但是感觉单纯的看文字内容不能很直观的反应出来大家的关切。索性就使用爬虫对数据进行爬取&#xff0c;同时结合着数据可视化的方式让数据自己开口说话。那么接下来就让我…

Python源码49:海龟画图turtle画美国旗

---------------turtle源码集合--------------- Python教程91&#xff1a;关于海龟画图&#xff0c;Turtle模块需要学习的知识点 Python源码45&#xff1a;海龟画图turtle画雪容融 Python源码44&#xff1a;海龟画图turtle&#xff0c;画2022卡塔尔世界杯吉祥物 Python教程…

前端JavaScript篇之实现有序数组原地去重方法有哪些?

目录 实现有序数组原地去重方法有哪些&#xff1f;方法一&#xff1a;使用 Set 数据结构代码实现&#xff1a;思路说明&#xff1a; 方法二&#xff1a;使用双指针遍历代码实现&#xff1a;思路说明&#xff1a; 实现有序数组原地去重方法有哪些&#xff1f; 在 JavaScript 中…

机器学习神器:Sklearn详解

引言 Sklearn (全称 Scikit-Learn) 是基于 Python 语言的机器学习工具。它建立在 NumPy, SciPy, Pandas 和 Matplotlib 之上&#xff0c;里面的 API 的设计非常好&#xff0c;所有对象的接口简单&#xff0c;很适合新手上路。 在 Sklearn 里面有六大任务模块&#xff1a;分别是…

怎样的安全数据交换系统 可以支持信创环境?

首先&#xff0c;我来看看&#xff0c;什么是安全数据交换系统&#xff1f;安全数据交换系统是一种专门设计用于在不同网络环境之间安全传输数据的技术解决方案。它确保数据在传输过程中的完整性、机密性和可用性&#xff0c;同时遵守相关的数据保护法规和行业标准。 那么&…

透明拼接屏显示:技术与应用

在当今的数字化时代&#xff0c;显示技术已成为我们日常生活和工作中的重要组成部分。透明拼接屏作为一种新型的显示技术&#xff0c;以其独特的透明设计和灵活的拼接特性&#xff0c;正逐渐在各个领域得到广泛应用&#xff0c;尼伽小编&#xff0c;将深入探讨透明拼接屏显示的…

灵感无限!12个设计师最爱的网站推荐,覆盖UX、网页设计和国外设计精华

即时设计资源广场 即时设计资源广场是中国优秀的UI设计网站&#xff0c;全中文环境&#xff0c;非常适合中国人使用。UI设计网站即时设计资源广场内置阿里、字节、腾讯、京东、谷歌、华为等设计系统&#xff0c;3000多个UI组件库&#xff0c;每月更新数百个高质量模板&#xf…

websocket服务端本地部署

文章目录 1. Java 服务端demo环境2. 在pom文件引入第三包封装的netty框架maven坐标3. 创建服务端,以接口模式调用,方便外部调用4. 启动服务,出现以下信息表示启动成功,暴露端口默认99995. 创建隧道映射内网端口6. 查看状态->在线隧道,复制所创建隧道的公网地址加端口号7. 以…

空气净化器or宠物空气净化器?五款猫用空气净化器优质推荐!

作为一个养猫家庭的主人&#xff0c;每天都要面对清理猫砂盘的挑战&#xff0c;这种令人难以形容的气味实在让人难以忍受。尤其是家里有小孩和老人&#xff0c;他们可能会出现过敏性鼻炎等问题&#xff0c;而抵抗力较差的人更容易受到影响。此外&#xff0c;换毛季节到来时&…

性能优化(CPU优化技术)-NEON指令介绍

「发表于知乎专栏《移动端算法优化》」 本文主要介绍了 NEON 指令相关的知识&#xff0c;首先通过讲解 arm 指令集的分类&#xff0c;NEON寄存器的类型&#xff0c;树立基本概念。然后进一步梳理了 NEON 汇编以及 intrinsics 指令的格式。最后结合指令的分类&#xff0c;使用例…