鸿蒙动态组件

一、需求背景

不同用户对同类型的密码文档有不同的输入要求,

例如一个开发服务器可能既想要保存服务器账号密码还想同时存储数据库帐号密码。

因此需要动态地添加输入组件,例如纯数字、日期、邮箱、网站、密码等输入组件。

二、实现过程

在实现动态组件之前,首先需要定义一个用于装载动态组件的变量。

接着,定义一个按钮事件,用于动态更新webFieldList中的组件。

接下来开始享用我们的主食啦,主要的界面代码部分如下:

其中,有一段代码非常重要,客观别急容我慢慢道来。

ForEach(array, itemGenerator, keyGenerator);

首先我在itemGenerator函数声明index参数,这个是用来处理一些需要排序或者密码输入框是否显示或隐藏时用到的,

例如下面这段代码,由于应用支持动态添加多个密码框,在用密码生成器的时候涉及到数值回填以及控制是否展示密码。

然后,我又定义了ForEach的第三个参数------keyGenerator函数,并在其中声明了index参数。

这里所做的,就是定义主键生成器,此时主键的值就是keyGenerator返回值。

因为鸿蒙系统的每个组件在渲染时都需要一个唯一值。如果您不设置生成规则,系统就会按照默认的生成机制去生成。

如果根据默认规则生成的值不是唯一的,就可能导致程序报错或其他不可预期的结果,例如组件位置添加不正确、UI 渲染性能降低等。

我总结了这个机制一共有5条:

1.如果没有定义keyGenerator,那生成规则就是:字符串index + '__' + JSON.stringify(item);

2.如果已定义keyGenerator函数,且keyGenerator函数和itemGenerator函数都未声明index,

那生成规则就是:keyGenerator函数的返回值;

3.如果已定义keyGenerator函数,且keyGenerator函数和itemGenerator函数都已声明index,

那生成规则就是:keyGenerator函数的返回值;(本文案例中的方式,声明了个寂寞除非确实需要用到index)

4.如果已定义keyGenerator函数且已声明index,但itemGenerator函数未声明index,

那生成规则就是:keyGenerator函数的返回值;

5.如果已定义keyGenerator函数且未声明index,但itemGenerator函数已声明index,

那生成规则就是:keyGenerator返回值与index的拼接字符串;(本案例如果采用此方式会导致渲染性能降低)

总而言之,言而总之,这样做的好处就一个字------能让您的应用跑得更快且不出毛病。

鸿蒙8月学习班:https://developer.huawei.com/consumer/cn/training/classDetail/35d902ec70a146f7a922cda1e714a8d8?type=1?ha_source=hmosclass\&ha_sourceId=89000248

相关推荐
●VON1 天前
HarmonyOS应用开发实战(基础篇)Day01-《ArkTS基本知识》
学习·华为·harmonyos·鸿蒙·von
仓颉编程语言2 天前
鸿蒙仓颉编程语言挑战赛二等奖作品:TaskGenie 打造基于仓颉语言的智能办公“任务中枢”
华为·鸿蒙·仓颉编程语言
_waylau3 天前
鸿蒙架构师修炼之道-架构师的职责是什么?
开发语言·华为·harmonyos·鸿蒙
坚果派·白晓明3 天前
在鸿蒙设备上快速验证由lycium工具快速交叉编译的C/C++三方库
c语言·c++·harmonyos·鸿蒙·编程语言·openharmony·三方库
熊猫钓鱼>_>3 天前
移动端开发技术选型报告:三足鼎立时代的开发者指南(2026年2月)
android·人工智能·ios·app·鸿蒙·cpu·移动端
ITUnicorn3 天前
【HarmonyOS6】ArkTS 自定义组件封装实战:动画水杯组件
华为·harmonyos·arkts·鸿蒙·harmonyos6
晚霞的不甘3 天前
Flutter for OpenHarmony 构建简洁高效的待办事项应用 实战解析
flutter·ui·前端框架·交互·鸿蒙
廖松洋(Alina)3 天前
【收尾以及复盘】flutter开发鸿蒙APP之成就徽章页面
flutter·华为·开源·harmonyos·鸿蒙
廖松洋(Alina)3 天前
【收尾以及复盘】flutter开发鸿蒙APP之打卡日历页面
flutter·华为·开源·harmonyos·鸿蒙
廖松洋(Alina)3 天前
【收尾以及复盘】flutter开发鸿蒙APP之本月数据统计页面
flutter·华为·开源·harmonyos·鸿蒙