harmony 鸿蒙ComposeListItem
ComposeListItem
The ComposeListItem component is a container that presents a series of items arranged in a column with the same width. You can use it to present data of the same type in a multiple and coherent row style, for example, images or text.
NOTE
This component is supported since API version 10. Updates will be marked with a superscript to indicate their earliest API version.
Modules to Import
import { ComposeListItem } from "@kit.ArkUI"
Child Components
Not supported
Attributes
The universal attributes are not supported.
ComposeListItem
ComposeListItem({contentItem?: ContentItem, operateItem?: OperateItem})
Decorator: @Component
System capability: SystemCapability.ArkUI.ArkUI.Full
Name | Type | Mandatory | Decorator | Description |
---|---|---|---|---|
contentItem | ContentItem | No | \@Prop | Elements on the left and in the center. Atomic service API: This API can be used in atomic services since API version 11. |
operateItem | OperateItem | No | \@Prop | Element on the right. Atomic service API: This API can be used in atomic services since API version 11. |
ContentItem
System capability: SystemCapability.ArkUI.ArkUI.Full
Name | Type | Mandatory | Description |
---|---|---|---|
iconStyle | IconType | No | Icon style of the element on the left. Atomic service API: This API can be used in atomic services since API version 11. |
icon | ResourceStr | No | Icon resource of the element on the left. Atomic service API: This API can be used in atomic services since API version 11. |
symbolStyle18+ | SymbolGlyphModifier | No | Symbol icon resource of the element on the left, which has higher priority than icon. Atomic service API: This API can be used in atomic services since API version 18. |
primaryText | ResourceStr | No | Primary text of the element in the center. Text processing rules: Text will wrap to a new line when it exceeds the length limit. Atomic service API: This API can be used in atomic services since API version 11. |
secondaryText | ResourceStr | No | Secondary text of the element in the center. Text processing rules: Text will wrap to a new line when it exceeds the length limit. Atomic service API: This API can be used in atomic services since API version 11. |
description | ResourceStr | No | Description of the element in the center. Text processing rules: Text will wrap to a new line when it exceeds the length limit. Atomic service API: This API can be used in atomic services since API version 11. |
IconType
Atomic service API: This API can be used in atomic services since API version 11.
System capability: SystemCapability.ArkUI.ArkUI.Full
Name | Value | Description |
---|---|---|
BADGE | 1 | Badge with an icon size of 8 x 8 vp. |
NORMAL_ICON | 2 | Small icon with an icon size of 16 x 16 vp. |
SYSTEM_ICON | 3 | System icon with an icon size of 24 x 24 vp. |
HEAD_SCULPTURE | 4 | Profile picture with an icon size of 40 x 40 vp. |
APP_ICON | 5 | Application icon with an icon size of 64 x 64 vp. |
PREVIEW | 6 | Preview image with an icon size of 96 x 96 vp. |
LONGITUDINAL | 7 | Icon with a horizontal special ratio (width is greater than height), keeping the longest side at 96 vp. |
VERTICAL | 8 | Icon with a vertical special ratio (height is greater than width), keeping the longest side at 96 vp. |
OperateItem
Atomic service API: This API can be used in atomic services since API version 11.
System capability: SystemCapability.ArkUI.ArkUI.Full
Name | Type | Mandatory | Description |
---|---|---|---|
arrow | OperateIcon | No | Arrow with a size of 12 x 24 vp. |
icon | OperateIcon | No | First icon with a size of 24 x 24 vp. |
subIcon | OperateIcon | No | Second icon with a size of 24 x 24 vp. |
button | OperateButton | No | Button. |
switch | OperateCheck | No | Switch. |
checkbox | OperateCheck | No | Check box with a size of 24 x 24 vp. |
radio | OperateCheck | No | Radio button with a size of 24 x 24 vp. |
image | ResourceStr | No | Image with a size of 48 x 48 vp. |
symbolStyle18+ | SymbolGlyphModifier | No | Symbol with a size of 48 x 48 vp. Atomic service API: This API can be used in atomic services since API version 18. |
text | ResourceStr | No | Text. |
OperateIcon
Atomic service API: This API can be used in atomic services since API version 11.
System capability: SystemCapability.ArkUI.ArkUI.Full
Name | Type | Mandatory | Description |
---|---|---|---|
value | ResourceStr | Yes | Resource of the icon or arrow on the right. |
symbolStyle18+ | SymbolGlyphModifier | No | Resource of the symbol icon or arrow on the right, which has higher priority than value. Atomic service API: This API can be used in atomic services since API version 18. |
action | ()=>void | No | Click event of the icon or arrow on the right. |
accessibilityText18+ | ResourceStr | No | Accessibility text, that is, accessible label name, of the icon or arrow on the right. If a component does not contain text information, it will not be announced by the screen reader when selected. In this case, the screen reader user cannot know which component is selected. To solve this problem, you can set accessibility text for components without text information. When such a component is selected, the screen reader announces the specified accessibility text, informing the user which component is selected. Default value: ”” Atomic service API: This API can be used in atomic services since API version 18. |
accessibilityDescription18+ | ResourceStr | No | Accessible description of the icon or arrow on the right. You can provide comprehensive text explanations to help users understand the operation they are about to perform and its potential consequences, especially when these cannot be inferred from the component’s attributes and accessibility text alone. If a component contains both text information and the accessible description, the text is announced first and then the accessible description, when the component is selected. Default value: “Double-tap to activate” Atomic service API: This API can be used in atomic services since API version 18. |
accessibilityLevel18+ | string | No | Accessibility level of the icon or arrow on the right. It determines whether the component can be recognized by accessibility services. The options are as follows: “auto”: It is treated as “no” by the system. “yes”: The component can be recognized by accessibility services. “no”: The component cannot be recognized by accessibility services. “no-hide-descendants”: Neither the component nor its child components can be recognized by accessibility services. Default value: “auto” Atomic service API: This API can be used in atomic services since API version 18. |
OperateButton
Atomic service API: This API can be used in atomic services since API version 11.
System capability: SystemCapability.ArkUI.ArkUI.Full
Name | Type | Mandatory | Description |
---|---|---|---|
text | ResourceStr | No | Text of the button on the right. |
accessibilityText18+ | ResourceStr | No | Accessibility text, that is, accessible label name, of the button on the right. If a component does not contain text information, it will not be announced by the screen reader when selected. In this case, the screen reader user cannot know which component is selected. To solve this problem, you can set accessibility text for components without text information. When such a component is selected, the screen reader announces the specified accessibility text, informing the user which component is selected. Atomic service API: This API can be used in atomic services since API version 18. |
accessibilityDescription18+ | ResourceStr | No | Accessible description of the button on the right. You can provide comprehensive text explanations to help users understand the operation they are about to perform and its potential consequences, especially when these cannot be inferred from the component’s attributes and accessibility text alone. If a component contains both text information and the accessible description, the text is announced first and then the accessible description, when the component is selected. Atomic service API: This API can be used in atomic services since API version 18. |
accessibilityLevel18+ | string | No | Accessibility level of the button on the right. It determines whether the component can be recognized by accessibility services. The options are as follows: “auto”: It is treated as “no” by the system. “yes”: The component can be recognized by accessibility services. “no”: The component cannot be recognized by accessibility services. “no-hide-descendants”: Neither the component nor its child components can be recognized by accessibility services. Default value: “auto” Atomic service API: This API can be used in atomic services since API version 18. |
OperateCheck
Atomic service API: This API can be used in atomic services since API version 11.
System capability: SystemCapability.ArkUI.ArkUI.Full
Name | Type | Mandatory | Description |
---|---|---|---|
isCheck | boolean | No | Whether the switch, check box, or radio button on the right is selected. Default value: false true: selected false: not selected |
onChange | (value: boolean)=>void | No | Callback invoked when the selected state of the switch, check box, or radio button on the right is changed. true: from not selected to selected false: from selected to not selected |
accessibilityText18+ | ResourceStr | No | Accessibility text, that is, accessible label name, of the switch, check box, or radio button on the right. If a component does not contain text information, it will not be announced by the screen reader when selected. In this case, the screen reader user cannot know which component is selected. To solve this problem, you can set accessibility text for components without text information. When such a component is selected, the screen reader announces the specified accessibility text, informing the user which component is selected. Atomic service API: This API can be used in atomic services since API version 18. |
accessibilityDescription18+ | ResourceStr | No | Accessible description of the switch, check box, or radio button on the right. You can provide comprehensive text explanations to help users understand the operation they are about to perform and its potential consequences, especially when these cannot be inferred from the component’s attributes and accessibility text alone. If a component contains both text information and the accessible description, the text is announced first and then the accessible description, when the component is selected. By default, the announcement rules for the basic components Switch, CheckBox, and Radio are applied. Atomic service API: This API can be used in atomic services since API version 18. |
accessibilityLevel18+ | string | No | Accessibility level of the switch, check box, or radio button on the right. It determines whether the component can be recognized by accessibility services. The options are as follows: “auto”: It is treated as “no” by the system. “yes”: The component can be recognized by accessibility services. “no”: The component cannot be recognized by accessibility services. “no-hide-descendants”: Neither the component nor its child components can be recognized by accessibility services. Default value: “auto” Atomic service API: This API can be used in atomic services since API version 18. |
Events
The universal events are not supported.
Example
Example 1: Configuring a Simple List Item
This example demonstrates how to create a simple list item that includes a primary text, a secondary text, a description, and a button with accompanying text on the right.
// This example demonstrates the basic functionality of the component, including the use of elements on the left and right.
import { IconType, ComposeListItem, promptAction } from '@kit.ArkUI';
@Entry
@Component
struct ComposeListItemExample {
build() {
Column() {
List() {
ListItem() {
ComposeListItem({
contentItem: ({
iconStyle: IconType.NORMAL_ICON,
icon: $r('sys.media.ohos_app_icon'),
primaryText: 'Double-line list',
secondaryText: 'Secondary text',
description: 'Description'
}),
operateItem: ({
icon: {
value: $r('sys.media.ohos_app_icon'),
action: () => {
promptAction.showToast({ message: 'icon' });
} },
text: 'Text on the right'
})
})
}
}
}
}
}
Example 2: Implementing Screen Reader Announcement for Right-Side Elements
This example shows how to use the accessibilityText, accessibilityDescription, and accessibilityLevel properties to customize the screen reader announcements for different right-side elements such as icons, buttons, and radio buttons in a list item.
import { IconType, ComposeListItem, promptAction } from '@kit.ArkUI';
@Entry
@Component
struct ComposeListItemExample {
build() {
Column() {
List() {
ListItem() {
ComposeListItem({
contentItem: ({
iconStyle: IconType.NORMAL_ICON,
icon: $r('sys.media.ohos_app_icon'),
primaryText: 'Double-line list',
secondaryText: 'Secondary text',
description: 'Description'
}),
operateItem: ({
radio: {
accessibilityText: 'Radio button', // Screen reader announcement for the radio button.
accessibilityDescription: 'Unselected', // Description read by screen reader when the radio button is unselected.
accessibilityLevel: 'yes' // Configure this element to be focused by accessibility screen readers.
}
})
})
}
ListItem() {
ComposeListItem({
contentItem: ({
iconStyle: IconType.NORMAL_ICON,
icon: $r('sys.media.ohos_app_icon'),
primaryText: 'Double-line list',
secondaryText: 'Secondary text',
description: 'Description'
}),
operateItem: ({
button: {
text: 'OK',
accessibilityText: 'This is a button',
accessibilityDescription: 'Double tap to activate',
accessibilityLevel: 'no' // Configure this button to be not recognizable by screen readers.
}
})
})
}
ListItem() {
ComposeListItem({
contentItem: ({
iconStyle: IconType.NORMAL_ICON,
icon: $r('sys.media.ohos_app_icon'),
primaryText: 'Double-line list',
secondaryText: 'Secondary text',
description: 'Description'
}),
operateItem: ({
icon: {
value: $r('sys.media.ohos_app_icon'),
action: () => {
promptAction.showToast({ message: 'icon' });
},
accessibilityText: 'This is an icon', // Screen reader announcement for the icon.
accessibilityDescription: 'Double-tap to show the toast', // Description read by screen reader for the icon action.
accessibilityLevel: 'yes' // Configure this element to be focused by screen readers.
}
})
})
}
}
}
}
}
Example 3: Setting the Symbol Icon
This example demonstrates how to use symbolStyle in ContentItem, OperateItem, and OperateIcon to set custom symbol icons.
import { IconType, ComposeListItem, promptAction, SymbolGlyphModifier } from '@kit.ArkUI';
@Entry
@Component
struct ComposeListItemExample {
build() {
Column() {
List() {
ListItem() {
ComposeListItem({
contentItem: ({
iconStyle: IconType.NORMAL_ICON,
icon: $r('sys.symbol.house'),
primaryText: 'Double-line list',
secondaryText: 'Secondary text',
description: 'Description'
}),
operateItem: ({
image: $r('sys.symbol.car'),
})
})
}
ListItem() {
ComposeListItem({
contentItem: ({
iconStyle: IconType.NORMAL_ICON,
icon: $r('sys.symbol.house'),
symbolStyle: new SymbolGlyphModifier($r('sys.symbol.bell')).fontColor([Color.Red]),
primaryText: 'Double-line list',
secondaryText: 'Secondary text',
description: 'Description'
}),
operateItem: ({
image: $r('sys.symbol.car'),
symbolStyle: new SymbolGlyphModifier($r('sys.symbol.heart')).fontColor([Color.Pink]),
})
})
}
ListItem() {
ComposeListItem({
contentItem: ({
iconStyle: IconType.NORMAL_ICON,
icon: $r('sys.symbol.house'),
symbolStyle: new SymbolGlyphModifier($r('sys.symbol.bell')).fontColor([Color.Blue]),
primaryText: 'Double-line list',
secondaryText: 'Secondary text',
description: 'Description'
}),
operateItem: ({
icon: {
value: $r('sys.symbol.car'),
symbolStyle: new SymbolGlyphModifier($r('sys.symbol.heart')).fontColor([Color.Orange]),
action: () => {
promptAction.showToast({ message: 'icon' });
}
}
})
})
}
}
}
}
}
你可能感兴趣的鸿蒙文章
- 所属分类: 后端技术
- 本文标签:
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
8、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦