【Harmony OS 4.0】渲染控制

2024-08-23 17:04
文章标签 控制 渲染 os 4.0 harmony

本文主要是介绍【Harmony OS 4.0】渲染控制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. if…else 条件渲染

  1. 根据应用的不同状态,渲染不同的UI界面。
  2. 修改条件分支的时候,会把原来的条件分支组件先删除,再重新创建一个条件分支组件。

1.1 代码示例如下:

// 自定义组件
@Component
struct MyChild {@Link count: number // @Link装饰器 - 父子双向同步 - 禁止本地初始化@Prop label: string // @Prop装饰器 - 父子单向同步 - 允许本地初始化build() {Row() {Flex({justifyContent: FlexAlign.Center, alignItems: ItemAlign.Center}) {Text(`${this.label}`)Button(`计数器${this.count}`).onClick(() => {this.count += 1})}}}
}@Entry
@Component
struct UITest6 {@State flag: boolean = true // @State装饰器 - 组件内状态 - 必须本地初始化@State parentCount: number = 0build() {Column() {if (this.flag) {MyChild({ count: $parentCount, label: '真真' })} else {MyChild({ count: $parentCount, label: '假假' })}Button(`是否真假:${this.flag}`).onClick(() => {this.flag = !this.flag}).margin(10)}}
}

2. 循环渲染

  1. 可使用 ForEach 语句基于一个数组来快速渲染一个组件列表。
  2. ForEach接口 基于 数组类型数据 来进行循环渲染,需要与容器组件配合使用,且接口返回的组件应当是允许包含在ForEach父容器组件中的子组件。
    例如,ListItem组件要求ForEach的父容器组件必须为List组件。
  3. 和 if…else 不一样,会做二次渲染,可以做到单独修改某一个值。

2.1 接收三个参数

ForEach(arr: any[],itemGenerator: (item: any, index?: number) => void,keyGenerator?: (item: any, index?: number) => string
)

2.1.1 arr

  1. 需要进行循环渲染的数据源,必须为数组类型。

2.1.2 itemGenerator

  1. 组件生成函数,用于为 arr 数组中的每个元素创建对应的组件。
  2. 该函数可接收俩个参数,分别是:
    item:arr 数组中的数据项,
    index(可选):arr 数组中的数据项的索引。

2.1.3 keyGenerator(可选)

  1. 是 key 生成函数,用于 arr 数组中的每个数据项生成唯一的 key
  2. key 的作用:
    ForEach 在数组发生变化时,需要重新渲染组件列表,再重新渲染时,它会尽量复用原来的组件对象,而不是重新渲染整个组件列表。
    key 的作用就是辅助 ForEach 完成组件对象的复用。
  3. 具体逻辑如下:
    ForEach 在进行初次渲染时,会使用 keyGenerator 为数组中的每个元素生成一个唯一的 key,并将 key 作为组件对象的标识。当数组发生变化导致 ForEach 需要重新渲染时,ForEach 会再次使用 keyGenerator 为每个元素重新生成一遍 key,然后 ForEach 会检查新生成的 key 在上次渲染时是否已经存在,若存在,ForEach 就会认为这个 key 对应的数组元素没有发生变化,那它就会直接复用这个 key 所对应的组件对象;若不存在,ForEach 就会认为这个 key 对应的元素发生了变化,或者该元素为新增元素,此时,就会为该元素重新创建一个组件对象。
  4. 如果开发者没有定义 keyGenerator函数,则系统会使用默认的 key 生成函数,即
(item: any, index: number) => { return index + '_' + JSON.stringify(item)}

在某些情况下默认的 key 生成函数,会导致界面渲染效率低下,此时可考虑通过 keyGenerator函数 自定义生成逻辑,即

ForEach(this.arr, (item) => {Text(item)}, item => JSON.stringify(item) )
  1. 在自定义 key 的生成逻辑时,必须得保证每个元素的 key 都是唯一的,这是规定好的。

2.2 代码示例如下:

// 自定义组件
@Component
struct MyChild {@Prop label: stringbuild() {Column() {Text(this.label).fontSize(24).fontColor("#9955FF")}}
}@Entry
@Component
struct UITest7 {@State my_array: Array<string> = ['one', 'two', 'three']build() {Column({space: 15}) {ForEach(this.my_array, (item: string, index: number) => { // ForEach接口基于数组类型数据来进行循环渲染,需要与容器组件配合使用。MyChild({label: item}) // 且接口返回的组件应当是允许包含在ForEach父容器组件中的子组件。})Button('修改two').onClick(() => {this.my_array[1] = 'new_two' // 和 if..else 不一样,会做二次渲染,可以做到单独修改某一个值。})}.justifyContent(FlexAlign.Center).height("100%").width('100%')}
}

这篇关于【Harmony OS 4.0】渲染控制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL精准控制Binlog日志数量的三种方案

《MySQL精准控制Binlog日志数量的三种方案》作为数据库管理员,你是否经常为服务器磁盘爆满而抓狂?Binlog就像数据库的“黑匣子”,默默记录着每一次数据变动,但若放任不管,几天内这些日志文件就... 目录 一招修改配置文件:永久生效的控制术1.定位my.cnf文件2.添加核心参数不重启热更新:高手应

Python Selenium动态渲染页面和抓取的使用指南

《PythonSelenium动态渲染页面和抓取的使用指南》在Web数据采集领域,动态渲染页面已成为现代网站的主流形式,本文将从技术原理,环境配置,核心功能系统讲解Selenium在Python动态... 目录一、Selenium技术架构解析二、环境搭建与基础配置1. 组件安装2. 驱动配置3. 基础操作模

SpringBoot请求参数接收控制指南分享

《SpringBoot请求参数接收控制指南分享》:本文主要介绍SpringBoot请求参数接收控制指南,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring Boot 请求参数接收控制指南1. 概述2. 有注解时参数接收方式对比3. 无注解时接收参数默认位置

Spring Security+JWT如何实现前后端分离权限控制

《SpringSecurity+JWT如何实现前后端分离权限控制》本篇将手把手教你用SpringSecurity+JWT搭建一套完整的登录认证与权限控制体系,具有很好的参考价值,希望对大家... 目录Spring Security+JWT实现前后端分离权限控制实战一、为什么要用 JWT?二、JWT 基本结构

Android实现两台手机屏幕共享和远程控制功能

《Android实现两台手机屏幕共享和远程控制功能》在远程协助、在线教学、技术支持等多种场景下,实时获得另一部移动设备的屏幕画面,并对其进行操作,具有极高的应用价值,本项目旨在实现两台Android手... 目录一、项目概述二、相关知识2.1 MediaProjection API2.2 Socket 网络

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

使用DrissionPage控制360浏览器的完美解决方案

《使用DrissionPage控制360浏览器的完美解决方案》在网页自动化领域,经常遇到需要保持登录状态、保留Cookie等场景,今天要分享的方案可以完美解决这个问题:使用DrissionPage直接... 目录完整代码引言为什么要使用已有用户数据?核心代码实现1. 导入必要模块2. 关键配置(重点!)3.

SpringSecurity 认证、注销、权限控制功能(注销、记住密码、自定义登入页)

《SpringSecurity认证、注销、权限控制功能(注销、记住密码、自定义登入页)》SpringSecurity是一个强大的Java框架,用于保护应用程序的安全性,它提供了一套全面的安全解决方案... 目录简介认识Spring Security“认证”(Authentication)“授权” (Auth

python之流程控制语句match-case详解

《python之流程控制语句match-case详解》:本文主要介绍python之流程控制语句match-case使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录match-case 语法详解与实战一、基础值匹配(类似 switch-case)二、数据结构解构匹