《HarmonyOSNext的ForEach数组渲染の核心玩法与避坑指南》

《HarmonyOSNext教学宝典:ForEach数组渲染全攻略与性能优化》
#HarmonyOS开发 #ArkTS实战 #组件解析

🎯 ForEach组件完全指南:数组循环渲染核心机制

举个栗子🌰:
ForEach相当于智能印刷机,将数组元素自动转化为UI组件!关键规则:​​必须搭配特定容器​​(如List中的ListItem

// 标准结构 ↓
ForEach(this.dataArray, (item: ItemType) => { /* 创建组件 */ }, (item: ItemType) => item.id /* 键值生成器 */
)

🔑 键值生成:组件的身份标识系统

ArkUI通过唯一键值(key) 追踪组件状态:

键值生成方式使用场景风险提示
(item,index) => index临时测试数据变动导致组件错乱 ⚠️
item => item基础类型不重复数组值重复时渲染异常 ⚠️
item => item.id含ID的对象数组推荐方案✅

📌 核心原则:键值重复会造成组件复用混乱(详见问题排查章节)


🏗️ 组件创建逻辑解析

场景1:首次渲染(新数组)
@State fruits: string[] = ['🍎','🍌','🍇'];build() {// 键值使用水果名称(仅限不重复数组)ForEach(this.fruits, (fruit) => {Text(fruit).fontSize(20) }, (fruit) => fruit)
}

输出结果:
🍎→新建组件 | 🍌→新建组件 | 🍇→新建组件


场景2:数据更新(非首次渲染)

点击修改第三个元素

Button('更新').onClick(() => {this.fruits[2] = '🥝' // 替换元素
})
元素旧键值新键值结果
🍎🍎🍎复用
🍌🍌🍌复用
🥝🍇🥝新建

💡 关键结论:仅键值变化的元素触发新建组件


🚀 四大实战模板

模板1:骨架屏加载
@State skeletonData: number[] = [1,2,3,4,5] ForEach(this.skeletonData, () => ArticleSkeletonView(), (num) => num.toString() // 数字键值避冲突
)

模板2:加载更多功能
List().onReachEnd(() => {// ✅ 正确操作:追加含ID的新对象this.newsList.push({id: Date.now(), title:'最新消息'})
})ForEach(this.newsList, (news) => NewsCard({news}),(news) => news.id // ID键值保证精准更新
)

模板3:属性监听(点赞功能)
// 关键配置
@Observed class Post {likesCount: number = 0 
}@Component
struct PostCard {@ObjectLink post: Postbuild() {Button(`点赞 ${this.post.likesCount}`).onClick(() => this.post.likesCount++)}
}

模板4:拖拽排序
ForEach(this.dragItems, (item) => {ListItem() { ... }.onMove((from, to) => {// ✅ 维持键值不变,仅交换数组位置const movingItem = this.dragItems.splice(from,1)[0]this.dragItems.splice(to, 0, movingItem)})
}, (item) => item.id) // 固定ID键值!

⚠️ 常见问题排查表

现象错误原因解决方案
新增数据渲染缺失使用索引(index)当键值改用对象唯一ID
拖拽后组件闪退数据重组时生成了新键值保持原始对象引用
属性更新界面不变直接替换整个对象仅修改对象属性字段
滚动加载全部重渲染键值生成规则不高效声明简单稳定键值(如ID)

💎 开发规范精要

// ✅ 安全高效的黄金写法
ForEach(数据源, (item) => 组件实例, (item) => item.uniqueID // 三点核心价值:
)
  1. 精准更新 - 避免全量重渲染
  2. 数据安全 - 防止组件复用错乱
  3. 性能保障 - 减少重复创建损耗

📢 重要提醒:

  • 基础类型数组建议转为{id:number, value:any}对象结构
  • 动态数组操作必须使用push()/splice()等变更检测方法

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

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

相关文章

单片机 - STM32F407 ADC 模式详解:单次转换、连续转换、扫描模式、非扫描模式

STM32F407 ADC 模式详解:单次转换、连续转换、扫描模式、非扫描模式 前言 在 STM32F407 中,ADC(模数转换器)模块常用于采集模拟信号,比如读取光敏电阻、电压、电流、温度传感器等。STM32 的 ADC 模式较多&#xff0c…

开源模型应用落地-工具使用篇-从零开始搭建Qdrant Web UI-可视化管理工具-Windows(十)

一、前言 Qdrant 是一个高性能的向量搜索引擎,广泛应用于相似性搜索、推荐系统和大规模数据检索等场景。虽然其原生 API 提供了强大的功能,但对于开发者和运维人员来说,缺乏直观的可视化界面常常增加了使用门槛。为了解决这一问题&#xff0c…

高频交易技术:订单簿分析与低延迟架构——从Level 2数据挖掘到FPGA硬件加速的全链路解决方案

高频交易技术:订单簿分析与低延迟架构——从Level 2数据挖掘到FPGA硬件加速的全链路解决方案 一、引言:高频交易的技术本质 1.1 速度即利润的微观战场 数据揭示:据NYSE实测,每降低1微秒延迟可获得年化$700-1500万套利窗口&#…

基于生成对抗网络(GAN)的图像生成与编辑:原理、应用与实践

前言 生成对抗网络(GAN)是近年来深度学习领域中最具影响力的技术之一。自2014年由Ian Goodfellow等人首次提出以来,GAN已经在图像生成、图像编辑、风格转换等多个领域取得了令人瞩目的成果。GAN的核心思想是通过生成器(Generator&…

pytorch基本运算-梯度运算:requires_grad_(True)和backward()

引言 前序学习进程中,已经对pytorch基本运算中的求导进行了基础讨论,相关文章链接为: 导数运算pytorch基本运算-导数和f-string-CSDN博客 实际上,求导是微分的进一步计算,要想求导的前一步其实是计算微分&#xff1…

idea64.exe.vmoptions配置

这个idea64.exe.vmoptions文件是用于配置 IntelliJ IDEA(64位版本)运行时的 Java 虚拟机(JVM)参数。这些参数直接影响到 IDEA 的性能、内存使用、调试能力和行为。 下面是对文件中每一行配置的详细解读: -Xms2048m 作…

齐次变换矩阵相乘的复合变换:左乘与右乘的深度解析

在三维几何变换中,齐次变换矩阵相乘是实现复杂变换的核心方法。本文将通过一个包含四个变换步骤的完整示例,深入探讨齐次变换矩阵左乘和右乘的区别,并结合 Python sympy 库的代码实现,详细阐述变换过程和结果差异。 二维齐次坐标的旋转变换 在二维齐次坐标系中,一个点可以…

5g LDPC编译码-LDPC编码

目录 1、LDPC编码基础知识 2、5g的LDPC编码 2.1 LDPC分块: 2.2 LDCP编码 2.3 校验位的产生 1、LDPC编码基础知识 LDPC属于线性分组码,线性分组码的基本知识如下: 编码后的码字是由初始二进制序列与生成矩阵在二进制域相乘后得到,生成矩阵与校验矩阵,校验矩阵与编码后…

OpenVINO使用教程--resnet分类模型部署

OpenVINO使用教程--resnet分类模型部署 本节内容模型准备推理测试分析&总结本节内容 OpenVINO 根据AI技术类型将部署任务分成传统模型模型部署和生成式AI模型部署,传统模型指的是各种CNN小模型,这部分部署只需要OpenVINO包,具体安装教程可以参考之前的章节:OpenVINO环境…

无字母数字webshell的命令执行

在Web安全领域,WebShell是一种常见的攻击手段,通过它攻击者可以远程执行服务器上的命令,获取敏感信息或控制系统。而无字母数字WebShell则是其中一种特殊形式,通过避免使用字母和数字字符,来绕过某些安全机制的检测。 …

C++斯特林数在C++中的数学理论与计算实现1

一、 斯特林数概述 1.1 组合数学中的核心地位 斯特林数(Stirling Numbers)是组合数学中连接排列、组合与分划问题的核心工具,分为两类: 第一类斯特林数(Stirling Numbers of the First Kind)&#xff1a…

[C++] STL大家族之<map>(字典)容器(附洛谷)

map-目录 使用方法头文件与声明定义基本操作 使用方法 头文件与声明定义 头文件是: #include <map>我们这样声明一个字典: map</*key_type*/, /*value_type*/> /*map_name*/; // 例子: map<int, char> mp;这里稍作解释: key_type是你每个键值对中的键的…

使用 Flutter 在 Windows 平台开发 Android 应用

以下是完整的开发流程&#xff0c;包括环境搭建、代码实现和应用发布&#xff0c;帮助你开发一个具有地图显示、TCP 通信功能的 Android 应用。 一、环境搭建 1. 安装 Flutter SDK 从 Flutter 官网 下载最新稳定版 SDK解压到本地目录&#xff08;如 D:\flutter&#xff09;添…

【模板】埃拉托色尼筛法(埃氏筛)

一、算法简介 在数论与编程竞赛中&#xff0c;求解 [ 1 , n ] [1,n] [1,n] 范围内的所有质数是常见的基础问题。埃拉托色尼筛法&#xff08;Sieve of Eratosthenes&#xff09; 是一种古老而高效的算法&#xff0c;可以在 O ( n log ⁡ log ⁡ n ) O(n \log \log n) O(nlogl…

AI Agent实战 - LangChain+Playwright构建火车票查询Agent

本篇文章将带你一步步构建一个智能火车票查询 Agent&#xff1a;你只需要输入自然语言指令&#xff0c;例如&#xff1a; “帮我查一下6月15号从上海到南京的火车票” Agent就能自动理解你的需求并使用 Playwright 打开 12306 官网查询前 10 条车次信息&#xff0c;然后汇总结果…

RabbitMQ的交换机和队列概念

&#x1f3ea; 场景&#xff1a;一个外卖平台的后台系统 假设你开了一家在线外卖平台&#xff1a; 饭店是消息的生产者&#xff08;Producer&#xff09;顾客是消息的消费者&#xff08;Consumer&#xff09;你开的外卖平台就是RabbitMQ消息系统 &#x1f501; 第一部分&…

德国马克斯·普朗克数学研究所:几何朗兰兹猜想

2025年科学突破奖 4月5日在美国洛杉矶揭晓&#xff1a;数学突破奖&#xff1a;德国马克斯普朗克数学研究所&#xff1a;几何朗兰兹猜想 德国马克斯普朗克数学研究所&#xff08;Max Planck Institute for Mathematics, MPIM&#xff09;在几何朗兰兹猜想的研究中扮演了核心角色…

TerraFE 脚手架开发实战系列(一):项目架构设计与技术选型

TerraFE 脚手架开发实战系列&#xff08;一&#xff09;&#xff1a;项目架构设计与技术选型 前言 在前端开发中&#xff0c;项目初始化往往是一个重复且繁琐的过程。每次新建项目都需要配置 webpack、安装依赖、设置目录结构等&#xff0c;这些重复性工作不仅浪费时间&#…

准确--CentOS 7.9在线安装docker

一、安装Docker前的准备工作 操作系统版本为CentOS 7.9&#xff0c;内核版本需要在3.10以上。确保能够连通互联网&#xff0c;为避免网络异常&#xff0c;建议关闭Linux的防火墙&#xff08;生产环境下请根据实际情况设置防火墙出入站规则&#xff09;。 # 查看内核版本 sudo…

中兴B860AV1.1强力降级固件包

中兴B860AV1.1强力降级固件包 关于中兴b860av1.1顽固盒子降级教程终极版 将附件解压好以后&#xff0c;准备一个8G以下的U盘重新格式化为FAT32格式后&#xff0c;并插入电脑 将以下文件及文件夹一同复制到优盘主目录下&#xff08;见下图&#xff09; 全选并复制到U盘主目录下&…