往期知识点整理
介绍
本案例通过List组件、组合手势GestureGroup、swipeAction属性以及attributeModifier属性等实现了列表项的交换和删除。
效果图预览
使用说明:
- 进入页面,长按列表项,执行拖拽操作,当拖拽长度大于列表项所占高度一半的时候,列表项进行交换。
- 列表项左滑,显示删除按钮,点击删除按钮,此列表项被删除。
实现思路
首先创建一个数组modifier来添加自定义属性对象,根据组合手势GestureGroup来控制自定义属性的值并通过attributeModifier绑定自定义属性对象来动态加载属性。
然后通过swipeAction属性绑定删除组件,左滑显示此删除组件,点击实现列表项的删除。
- 声明一个数组,添加自定义属性对象,每个自定义属性对象对应一个列表项。
constructor(deductionData: Array<T>) {
this.deductionData = deductionData;
this.modifier = new Array<ListItemModifier>();
deductionData.forEach(() => {
this.modifier.push(new ListItemModifier());
})
}
/**
* 通过实现AttributeModifier接口,自定义属性修改器
* 将拖拽排序相关样式封装成属性修改器,可以方便移植
*/
export class ListItemModifier implements AttributeModifier<ListItemAttribute> {
public hasShadow: boolean = false;
public isDeleted: boolean = false;
public scale: number = 1;
public offsetY: number = 0;
public offsetX: number = 0;
public opacity: number = 1;
public static instance: ListItemModifier | null = null;
public static getInstance(): ListItemModifier {
if (!ListItemModifier.instance) {
ListItemModifier.instance = new ListItemModifier();
}
return ListItemModifier.instance;
}
/**
* 定义组件普通状态时的样式
* @param instance
*/
applyNormalAttribute(instance: ListItemAttribute): void {
if (this.hasShadow) {
instance.shadow({ radius: $r('app.integer.list_exchange_shadow_radius'), color: $r('app.color.box_shadow') });
instance.zIndex(1);
instance.opacity(0.5);
} else {
instance.opacity(this.opacity);
}
instance.translate({ x: this.offsetX, y: this.offsetY });
instance.scale({ x: this.scale, y: this.scale });
}
}
- 绑定attributeModifier属性以及组合手势GestureGroup,attributeModifier属性的值为对应的自定义属性对象。
// 列表区域
List() {
ForEach(this.appInfoList, (item: ListInfo) => {
ListItem() {
DeductionView