网站个人中心wordpress/友情链接英文翻译

网站个人中心wordpress,友情链接英文翻译,怀化信访网站,婚庆策划温馨提示:本篇博客的详细代码已发布到 git : https://gitcode.com/nutpi/HarmonyosNext 可以下载运行哦! 目录 一、代码结构概览二、详细代码解析1. 数据源管理实现2. 数据结构定义3. 优化的列表项组件4. 主列表组件实现 一、代码结构概览 本文将详细解…

温馨提示:本篇博客的详细代码已发布到 git : https://gitcode.com/nutpi/HarmonyosNext 可以下载运行哦!

目录

    • 一、代码结构概览
    • 二、详细代码解析
      • 1. 数据源管理实现
      • 2. 数据结构定义
      • 3. 优化的列表项组件
      • 4. 主列表组件实现

一、代码结构概览

本文将详细解析一个基于 HarmonyOS Next API 12 实现的高性能列表渲染示例。该示例展示了如何通过合理的代码组织和多种优化技巧来提升列表性能。主要包含以下几个核心部分:

  1. 数据源管理(ArrayDataSource 类)
  2. 数据结构定义(ItemData 接口)
  3. 优化的列表项组件(OptimizedListItem)
  4. 主列表组件(ListDemo)

案例运行效果如下

二、详细代码解析

1. 数据源管理实现

class ArrayDataSource implements IDataSource {private dataArray: ItemData[];constructor(data: ItemData[]) {this.dataArray = data;}totalCount(): number {return this.dataArray.length;}getData(index: number): ItemData {return this.dataArray[index];}registerDataChangeListener(listener: DataChangeListener): void {// 简单实现可暂不处理}unregisterDataChangeListener(listener: DataChangeListener): void {// 简单实现可暂不处理}
}

性能优化要点:

  1. 数据源封装

    • 实现 IDataSource 接口,提供标准化的数据访问方式
    • 通过 getData 方法实现数据的按需加载,避免一次性加载全部数据
    • totalCount 方法提供数据总量信息,便于 LazyForEach 进行渲染优化
  2. 数据变更监听机制

    • 提供数据变更监听接口,支持数据动态更新
    • 可以根据实际需求实现更复杂的数据变更处理逻辑

2. 数据结构定义

interface ItemData {id: numbertitle: stringdescription: stringavatar: stringtype: 'simple' | 'badge'unreadCount?: number
}

优化考虑:

  1. 类型安全

    • 使用 TypeScript 接口定义数据结构,提供类型检查
    • 通过可选属性(unreadCount?)优化内存占用
  2. 数据结构设计

    • 使用 type 字段区分不同类型的列表项,支持条件渲染
    • 合理组织数据字段,避免冗余信息

3. 优化的列表项组件

@Component
struct OptimizedListItem {@Prop item: ItemData@BuilderItemContent() {Row() {Image(this.item.avatar).width(40).height(40).margin({ right: 10 })Column() {Text(this.item.title).fontSize(16).fontWeight(FontWeight.Medium)Text(this.item.description).fontSize(14).opacity(0.6)}.alignItems(HorizontalAlign.Start)}.width('100%').padding(10).backgroundColor('#F5F5F5').border({width: 1,color: '#E0E0E0',style: BorderStyle.Solid})}build() {if (this.item.type === 'simple') {this.ItemContent()} else {Stack() {this.ItemContent()Badge({value: this.item.unreadCount+'',position: BadgePosition.RightTop,style: { badgeSize: 16, badgeColor: '#FA2A2D' }}) {Text('').width(40).height(40)}}}}
}

性能优化策略:

  1. 组件复用

    • 使用 @Builder 装饰器定义可复用的 ItemContent 子组件
    • 避免重复创建相同的 UI 结构,减少内存占用
  2. 条件渲染

    • 根据 item.type 进行条件渲染,只渲染必要的 UI 元素
    • 简单类型直接渲染 ItemContent,复杂类型添加 Badge 组件
  3. 属性传递优化

    • 使用 @Prop 装饰器接收数据,避免数据重复
    • 通过单一数据对象传递,减少属性传递开销
  4. 布局优化

    • 使用 Row 和 Column 组件实现高效的弹性布局
    • 通过 Stack 组件实现 Badge 的叠加效果,避免复杂的定位计算

4. 主列表组件实现

@Entry
@Component
struct ListDemo {@State dataList: ItemData[] = [{id: 1,title: '消息通知',description: '您有一条新的系统通知',avatar: '/assets/userPhone.JPG',type: 'badge',unreadCount: 3},{id: 2,title: '系统更新',description: '系统有新版本可用',avatar: '/assets/userPhone.JPG',type: 'simple'}]build() {List() {LazyForEach(new ArrayDataSource(this.dataList), (item: ItemData) => {ListItem() {OptimizedListItem({ item: item })}.onClick(() => {console.info(`Clicked item: ${item.title}`)})}, (item: ItemData) => item.id.toString())}.width('100%').height('100%')}
}

核心优化策略:

  1. LazyForEach 懒加载

    • 使用 LazyForEach 替代普通的 ForEach,实现列表项的按需渲染
    • 配合 ArrayDataSource 实现高效的数据管理
  2. 状态管理

    • 使用 @State 装饰器管理列表数据,支持响应式更新
    • 数据变更时只更新必要的 UI 部分
  3. 唯一键优化

    • 为每个列表项提供唯一的 key(item.id.toString())
    • 帮助框架更好地进行 DOM diff 和更新优化
  4. 事件处理

    • 在 ListItem 级别处理点击事件,避免事件冒泡
    • 通过闭包保存当前项的数据,无需额外的数据查找

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

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

相关文章

vscode 查看3d

目录 1. vscode-3d-preview obj查看ok 2. vscode-obj-viewer 没找到这个插件: 3. 3D Viewer for Vscode 查看obj失败 1. vscode-3d-preview obj查看ok 可以查看obj 显示过程:开始是绿屏,过了1到2秒,后来就正常看了。 2. vsc…

excel 斜向拆分单元格

右键-合并单元格 右键-设置单元格格式-边框 在设置好分割线后,你可以开始输入文字。 需要注意的是,文字并不会自动分成上下两行。 为了达到你期望的效果,你可以通过 同过左对齐、上对齐 空格键或使用【AltEnter】组合键来调整单元格中内容的…

家政保洁维修行业有没有必要做小程序?

【家政创业必看】家政行业小程序值得做吗?4大核心优势告诉你! 随时随地下单:客户手机一键预约,告别找电话/翻页面的麻烦 品牌专业升级:精美界面服务详情用户评价,打造可信赖形象 营销神器&#xff1…

libcoap在Ubuntu下的编译(基于CMake)

引言 libcoap 是一个开源的轻量级 C 语言库,用于实现 CoAP(Constrained Application Protocol,受限应用协议)。CoAP 是一种专为资源受限设备设计的轻量级通信协议,适用于物联网(IoT)和嵌入式系…

VSCode知名主题带毒 安装量900万次

目前微软已经从 Visual Studio Marketplace 中删除非常流行的主题扩展 Material Theme Free 和 Material Theme Icons,微软称这些主题扩展包含恶意代码。 统计显示这些扩展程序的安装总次数近 900 万次,在微软实施删除后现在已安装这些扩展的开发者也会…

如何快速的解除oracle dataguard

有些时候,我们为了使oracle dg的standby库另做他用,需要解除oracle dataguard数据同步。我本地因为standby库存储出现故障,导致dg存在问题,故需要解除。今天,我们通过使用部分命令,实现dg的快速解除。 1&a…

Windows系统编程(七)HotFixHook

InoolineHook需要读写两次内存(先HOOK,再还原),这种Hook方式,性能比较低,具有局限性。今天所讲的HotFixHOOK(热补丁)是InlineHook的升级版 Win32 API特殊性 Win32API的实现代码有这…

TCP通讯与基于C#TCP通讯,跨窗收发消息Demo

TCP(传输控制协议)是一种面向连接的、可靠的、基于字节流的传输层通信协议。它广泛应用于互联网中的数据通信,如网页浏览、文件传输、电子邮件等。以下是TCP通信的基本概念和工作原理: 1. TCP的特点 面向连接:通信前…

【有源码】仿DeepSeek问答网站+SpringBoot+VUE3+对接DeepSeek API

今天带来一款优秀的项目:仿DeepSeek问答网站。 功能和官网差不多,也有历史上下文,流失对话等。 本文介绍了系统功能与部署安装步骤,如果您有任何问题,也请联系学姐,偶现在是经验丰富的程序员! …

Ubuntu20.04双系统安装及软件安装(七):Anaconda3

Ubuntu20.04双系统安装及软件安装(七):Anaconda3 打开Anaconda官网,在右侧处填写邮箱(要真实有效!),然后Submit。会出现如图示的Success界面。 进入填写的邮箱,有一封Ana…

洛谷 P2142 高精度减法(详解)c++

题目链接:P2142 高精度减法 - 洛谷 1.题目 2.算法原理 解法:模拟列竖式计算的过程 先用字符串读入,然后拆分每一位,逆序放进数组中利用数组,模拟列竖式减法的过程 在这两步之前要多加一步,在模拟解法的过程&#…

微服务组件详解——sentinel

1.启动sentinel: 下载jar sentinel-dashboard-1.8.0.jar 使用以下命令直接运行 jar 包(JDK 版本必须≥ 1.8): java -Dserver.port9999 -jar D:\sentinel-dashboard-1.8.0.jar 控制台访问地址:http://localhost:9999…

AI数据分析:deepseek生成SQL

在当今数据驱动的时代,数据分析已成为企业和个人决策的重要工具。随着人工智能技术的快速发展,AI 驱动的数据分析工具正在改变我们处理和分析数据的方式。本文将着重介绍如何使用 DeepSeek 进行自动补全SQL 查询语句。 我们都知道,SQL 查询语…

动态规划01背包问题系列一>目标和

目录 题目分析及优化:状态表示:状态转移方程:初始化:填表顺序:返回值:代码呈现:优化:代码呈现: 题目分析及优化: 状态表示: 状态转移方程&#xf…

Linux 基础---sudo权限 修改文件所属人、用户所属组

sudo 概念:让普通用户使用管理员权限执行一些操作(root) 在命令前加上sudo 即可 修改文件所属人、所属组

HMC7043和HMC7044芯片配置使用

一,HMC7043芯片 MC7043独特的特性是对14个通道分别进行独立灵活的相位管理。所有14个通道均支持频率和相位调整。这些输出还可针对50 Ω或100 Ω内部和外部端接选项进行编程。HMC7043器件具有RF SYNC功能,支持确定性同步多个HMC7043器件,即确保所有时钟输出从同一时钟沿开始…

【动手实验】TCP半连接队列、全连接队列实战分析

本文是对 从一次线上问题说起,详解 TCP 半连接队列、全连接队列 这篇文章的实验复现和总结,借此加深对 TCP 半连接队列、全连接队列的理解。 实验环境 两台腾讯云服务器 node2(172.19.0.12) 和 node3(172.19.0.15&am…

大模型训练微调技术介绍

大模型训练微调技术是人工智能领域中的一项重要技术,旨在通过少量特定领域的数据对预训练模型进行进一步训练,使其更好地适应具体任务或应用场景。以下是关于大模型训练微调技术的详细介绍: 1. 微调技术的定义与意义 微调(Fine-…

javaweb自用笔记:Vue

Vue 什么是vue vue案例 1、引入vue.js文件 2、定义vue对象 3、定义vue接管的区域el 4、定义数据模型data 5、定义视图div 6、通过标签v-model来绑定数据模型 7、{{message}}直接将数据模型message展示出来 8、由于vue的双向数据绑定,当视图层标签input里的…

基于eRDMA实测DeepSeek开源的3FS

DeepSeek昨天开源了3FS分布式文件系统, 通过180个存储节点提供了 6.6TiB/s的存储性能, 全面支持大模型的训练和推理的KVCache转存以及向量数据库等能力, 每个客户端节点支持40GB/s峰值吞吐用于KVCache查找. 发布后, 我们在阿里云ECS上进行了快速的复现, 并进行了性能测试, ECS…