# List 列表包含一系列相同宽度的列表项。适合连续、多行呈现同类数据,例如图片和文本。 ## 权限列表 无 ## 子组件 包含[ListItem](ts-container-listitem.md)子组件。 ## 接口 List\(options?: \{ space?: number, initialIndex?: number \}\) - 参数

参数名

参数类型

必填

默认值

参数描述

space

number

0

列表项间距。

initialIndex

number

0

设置当前List初次加载时视口起始位置显示的item,即显示第一个item,如设置的序号超过了最后一个item的序号,则设置不生效。

## 属性

名称

参数类型

默认值

描述

listDirection

Axis

Vertical

设置List组件排列方向参照Axis枚举说明。

divider

{

strokeWidth: Length,

color?:Color,

startMargin?: Length,

endMargin?: Length

}

-

用于设置ListItem分割线样式,默认无分割线。

strokeWidth: 分割线的线宽。

color: 分割线的颜色。

startMargin: 分割线距离列表侧边起始端的距离。

endMargin: 分割线距离列表侧边结束端的距离。

editMode

boolean

false

声明当前List组件是否处于可编辑模式。

edgeEffect

EdgeEffect

Spring

滑动效果,目前支持的滑动效果参见EdgeEffect的枚举说明。

chainAnimation

boolean

false

用于设置当前list是否启用链式联动动效,开启后列表滑动以及顶部和底部拖拽时会有链式联动的效果。链式联动效果:list内的list-item间隔一定距离,在基本的滑动交互行为下,主动对象驱动从动对象进行联动,驱动效果遵循弹簧物理动效。

  • false:不启用链式联动。
  • true:启用链式联动。
- Axis枚举说明

名称

描述

Vertical

纵向排列。

Horizontal

横向排列。

- EdgeEffect枚举说明

名称

描述

Spring

弹性物理动效,滑动到边缘后可以根据初始速度或通过触摸事件继续滑动一段距离,松手后回弹。

None

滑动到边缘后无效果。

## 事件

名称

功能描述

onItemDelete(index: number) => boolean

列表项删除时触发。

onScrollIndex(firstIndex: number, lastIndex: number) => void

当前列表显示的起始位置和终止位置发生变化时触发。

>![](../../public_sys-resources/icon-note.gif) **说明:** >List使能可编辑模式需配合事件方法onItemDelete和ListItem的editable属性,即可编辑模式实现删除列表项功能,需满足下列三个条件: >- 配置editMode\(true\); >- 绑定onItemDelete回调,回调中return true; >- ListItem属性editable\(true\)。 ## 示例 ``` @Entry @Component struct ListExample { private arr: number[] = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] @State editFlag: boolean = false build() { Stack({ alignContent: Alignment.TopStart }) { Column() { List({ space: 20, initialIndex: 0 }) { ForEach(this.arr, (item) => { ListItem() { Text('' + item) .width('100%').height(100).fontSize(16) .textAlign(TextAlign.Center).borderRadius(10).backgroundColor(0xFFFFFF) }.editable(true) }, item => item) } .listDirection(Axis.Vertical) // 排列方向 .divider({ strokeWidth: 2, color: 0xFFFFFF, startMargin: 20, endMargin: 20 }) // 每行之间的分界线 .edgeEffect(EdgeEffect.None) // 滑动到边缘无效果 .chainAnimation(false) // 联动特效关闭 .onScrollIndex((firstIndex: number, lastIndex: number) => { console.info('first' + firstIndex) console.info('last' + lastIndex) }) .editMode(this.editFlag) .onItemDelete((index: number) => { console.info(this.arr[index] + 'Delete') this.arr.splice(index, 1) console.info(JSON.stringify(this.arr)) this.editFlag = false return true }).width('90%') }.width('100%') Button('edit list') .onClick(() => { this.editFlag = !this.editFlag }).margin({ top: 5, left: 20 }) }.width('100%').height('100%').backgroundColor(0xDCDCDC).padding({ top: 5 }) } } ``` ![](figures/list.gif)