列表item分组
该组件用来展示列表item分组,宽度默认充满List组件,必须配合List组件来使用。
该组件从API Version 9开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
使用说明
当ListItemGroup的父组件List的listDirection属性为Axis.Vertical时,不允许设置ListItemGroup组件的height属性。
ListItemGroup的高度为header高度、footer高度和所有ListItem布局后总高度之和。当父组件List的listDirection属性为Axis.Horizontal时,不允许设置ListItemGroup组件的width属性。ListItemGroup的宽度为header宽度、footer宽度和所有ListItem布局后总宽度之和。
当前ListItemGroup内部的ListItem组件不支持编辑、框选、拖拽功能,即ListItem组件的editable、selectable属性不生效。
接口
ListItemGroup(options?: {header?: CustomBuilder, footer?: CustomBuilder, space?: number | string})
参数:
参数名 | 参数类型 | 必填 | 参数描述 |
---|---|---|---|
header | 否 | 设置ListItemGroup头部组件。 | |
footer | 否 | 设置ListItemGroup尾部组件。 | |
space | number | string | 否 | 列表项间距。只作用于ListItem与ListItem之间,不作用于header与ListItem、footer与ListItem之间。 |
属性
名称 | 参数类型 | 描述 |
---|---|---|
divider | { strokeWidth: Length, color?: ResourceColor, startMargin?: Length, endMargin?: Length } | null | 用于设置ListItem分割线样式,默认无分割线。 strokeWidth: 分割线的线宽。 color: 分割线的颜色。 startMargin: 分割线距离列表侧边起始端的距离。 endMargin: 分割线距离列表侧边结束端的距离。 strokeWidth, startMargin和endMargin不支持设置百分比。 |
ListItemGroup组件不支持设置通用属性aspectRatio。
ListItemGroup组件如果主轴方向是垂直方向时,设置通用属性height属性不生效。
ListItemGroup组件如果主轴方向是水平方向时,设置通用属性width属性不生效。
示例
- // xxx.ets
- @Entry
- @Component
- struct ListItemGroupExample {
- private timetable: any = [
- {
- title:'星期一',
- projects:['语文', '数学', '英语']
- },
- {
- title:'星期二',
- projects:['物理', '化学', '生物']
- },
- {
- title:'星期三',
- projects:['历史', '地理', '政治']
- },
- {
- title:'星期四',
- projects:['美术', '音乐', '体育']
- }
- ]
- @Builder itemHead(text:string) {
- Text(text)
- .fontSize(20)
- .backgroundColor(0xAABBCC)
- .width("100%")
- .padding(10)
- }
- @Builder itemFoot(num:number) {
- Text('共' + num + "节课")
- .fontSize(16)
- .backgroundColor(0xAABBCC)
- .width("100%")
- .padding(5)
- }
- build() {
- Column() {
- List({ space: 20 }) {
- ForEach(this.timetable, (item) => {
- ListItemGroup({ header:this.itemHead(item.title), footer:this.itemFoot(item.projects.length) }) {
- ForEach(item.projects, (project) => {
- ListItem() {
- Text(project)
- .width("100%").height(100).fontSize(20)
- .textAlign(TextAlign.Center).backgroundColor(0xFFFFFF)
- }
- }, item => item)
- }
- .borderRadius(20)
- .divider({ strokeWidth: 1, color: Color.Blue }) // 每行之间的分界线
- })
- }
- .width('90%')
- .sticky(StickyStyle.Header|StickyStyle.Footer)
- }.width('100%').height('100%').backgroundColor(0xDCDCDC).padding({ top: 5 })
- }
- }