1# list 2 3 4The **\<list>** component provides a list container that presents a series of list items arranged in a column with the same width. It supports presentations of the same type of data in a multiple and coherent row style, for example, images or text. 5 6> **NOTE** 7> 8> The APIs of this module are supported since API version 8. Updates will be marked with a superscript to indicate their earliest API version. 9> 10> Limit the number of items in a list to 30 to improve user experience. 11 12 13 14 15## Child Components 16 17Only the **[\<list-item>](js-service-widget-container-list-item.md)** child component is supported. 18 19 20## Attributes 21 22In addition to the [universal attributes](js-service-widget-common-attributes.md), the following attributes are supported. 23 24| Name | Type | Default Value | Mandatory | Description | 25| ------------- | -------------- | ------- | ---- | ---------------------------------------- | 26| cachedcount | number | 0 | No | Minimum number of cached list items when a long list is loaded with delay. | 27| scrollbar | string | off | No | Display mode of the side scrollbar. (Currently, only the vertical scrollbar is supported.)<br>- **off**: no display.<br>- **auto**: displayed on demand (The side scrollbar is displayed when touched and disappears 2s later.).<br>- **on**: always on display. | 28| scrolleffect | string | spring | No | Scroll effect. Available values are as follows:<br>- **spring**: Similar to the physical dynamic effect of a spring. When the scrollbar reaches the edge, it can continue to scroll for a distance based on the initial speed or a touch event. It rebounds after being released.<br>- **fade**: Similar to the physical dynamic effect of fade. When you scroll to the edge, a wave shape fades. The fade changes according to the speed and scrolling distance.<br>- **none**: No effect when the scrollbar reaches the edge.| 29| divider | boolean | false | No | Whether list items are separated by dividers.<br>For details, see **divider-color**, **divider-height**, **divider-length**, and **divider-origin** in [Styles](#styles).| 30| shapemode | string | default | No | Shape of the side scrollbar.<br>- **default**: not specified (following the theme).<br>- **rect**: rectangle.<br>- **round**: circle.| 31| updateeffect | boolean | false | No | Whether a dynamic effect is displayed when an item in the list is deleted or added.<br>- **false**: No dynamic effect is displayed.<br>- **true**: A dynamic effect is displayed when an item is added or deleted.| 32| initialindex | number | 0 | No | Item displayed at the start position of the viewport when the list is loaded for the first time. The default value is **0**, indicating that the first item is displayed. If the number you set is greater than the index of the last item, the setting does not take effect. When the **initialoffset** attribute is set, this attribute does not take effect. | 33| initialoffset | <length> | 0 | No | Start offset of the viewport when the list is loaded for the first time. The offset must not exceed the scrolling range of the list. If exceeded, the offset is truncated to the maximum value of the scrolling range. | 34| selected | string | - | No | Selected item in the list. The value can be a **section** value of any list items. | 35 36 37## Styles 38 39In addition to the [universal styles](js-service-widget-common-styles.md), the following styles are supported. 40 41| Name | Type | Default Value | Mandatory | Description | 42| ---------------- | ---------------------------------------- | ----------- | ---- | ---------------------------------------- | 43| divider-color | <color> | transparent | No | Item divider color. This style is valid only when the **divider** attribute of **\<list>** is set to **true**. | 44| divider-height | <length> | 1 | No | Item divider height. This style is valid only when the **divider** attribute of **\<list>** is set to **true**. | 45| divider-length | <length> | The main axis width | No | Item divider length. If this style is not set, the maximum length is the width of the main axis, and the actual length depends on the **divider-origin** parameter. This style is valid only when the **divider** attribute of **\<list>** is set to **true**.| 46| divider-origin | <length> | 0 | No | Item divider offset relative to the start point of the main axis. This style is valid only when the **divider** attribute of **\<list>** is set to **true**.| 47| flex-direction | string | column | No | Main axis direction of the flex container. It specifies how items are placed in the flex container.<br>- **column**: The y-axis is the main axis.<br>- **row**: The x-axis is the main axis.<br>For the **\<list>** component, the default value is **column**. For other components, the default value is **row**.| 48| columns | number | 1 | No | Number of columns displayed in the cross axis direction of the list. The default value is **1**.<br>When multiple columns are set, the columns are evenly distributed on the cross axis of the **\<list>** component. The size of each column is the same.| 49| align-items | string | stretch | No | Alignment of items in each column on the cross axis. Available values are as follows:<br>- **stretch**: Items are stretched to the same height or width as the container along the cross axis.<br>- **flex-start**: Items are packed toward the start edge of the cross axis.<br>- **flex-end**: Items are packed toward the end edge of the cross axis.<br>- **center**: Items are packed toward the center of the cross axis.<br>This style takes effect only on items of each column. Columns are evenly distributed.| 50| item-extent | <length> \| <percentage> | - | No | Size of an internal item. When a percentage is set, the value indicates the percentage of the length in the main axis direction relative to the list viewpoint.| 51| fade-color | <color> | grey | No | Color of the physical dynamic effect. This attribute is valid only when **scrolleffect** is set to **fade**. | 52| scrollbar-color | <color> | - | No | Color of the scrollbar. | 53| scrollbar-width | <length> | - | No | Width of the scrollbar. | 54| scrollbar-offset | <length> | 0 | No | Offset between the scrollbar and the default position of the list. The value must be a positive number. The default position is on the right edge of the list. You can adjust the horizontal position of the scrollbar by setting this offset. If the scrollbar is drawn outside the list and the parent component of the list is capable of cropping, the scrollbar will be cropped.| 55 56 57## Events 58 59The [universal events](js-service-widget-common-events.md) are supported. 60 61 62## Example 63 64 65```html 66<!-- index.hml --> 67<div class="container"> 68 <list class="todo-wraper"> 69 <list-item for="{{todolist}}" class="todo-item"> 70 <text class="todo-title">{{$item.title}}</text> 71 <text class="todo-title">{{$item.date}}</text> 72 </list-item> 73 </list> 74</div> 75``` 76 77 78```json 79{ 80 "data": { 81 "todolist": [{ 82 "title": "work", 83 "date": "2021-12-31 10:00:00" 84 }, { 85 "title": "watch movie", 86 "date": "2021-12-31 20:00:00" 87 }] 88 } 89} 90``` 91 92 93```css 94/* index.css */ 95.container { 96 display: flex; 97 justify-content: center; 98 align-items: center; 99 left: 0px; 100 top: 0px; 101 width: 454px; 102 height: 454px; 103} 104.todo-wraper { 105 width: 454px; 106 height: 300px; 107} 108.todo-item { 109 width: 454px; 110 height: 80px; 111 flex-direction: column; 112} 113.todo-title { 114 width: 454px; 115 height: 40px; 116 text-align: center; 117} 118``` 119**4 x 4 widget** 120 121![en-us_image_0000001231370803](figures/en-us_image_0000001231370803.png) 122