This is documentation for the next SDK version. For up-to-date documentation, see the latest version (SDK 55).
LazyRow
用于显示水平滚动列表的 Jetpack Compose LazyRow 组件。
For the complete documentation index, see llms.txt. Use this Use this file to discover all available pages.
一个懒加载的水平列表组件,只渲染可见项,以实现高效滚动。有关更多信息,请参阅 官方 Jetpack Compose 文档。
安装
- npx expo install @expo/uiIf you are installing this in an existing React Native app, make sure to install expo in your project.
用法
基础懒加载行
import { Host, LazyRow, Text } from '@expo/ui/jetpack-compose'; const items = Array.from({ length: 100 }, (_, i) => `Item ${i + 1}`); export default function BasicLazyRow() { return ( <Host style={{ height: 100 }}> <LazyRow> {items.map(item => ( <Text key={item}>{item}</Text> ))} </LazyRow> </Host> ); }
带排列方式
使用 horizontalArrangement 属性来控制项目在列表中的间距。传入像 'spaceBetween' 这样的字符串值,或者像 { spacedBy: 8 } 这样的对象,以在 dp 中设置固定间距。
import { Host, LazyRow, Text } from '@expo/ui/jetpack-compose'; export default function LazyRowArrangement() { return ( <Host style={{ height: 100 }}> <LazyRow horizontalArrangement={{ spacedBy: 16 }} verticalAlignment="center"> <Text>间隔项 1</Text> <Text>间隔项 2</Text> <Text>间隔项 3</Text> </LazyRow> </Host> ); }
带内容内边距
使用 contentPadding 属性可为列表内容四周添加 dp 内边距。
import { Host, LazyRow, Text } from '@expo/ui/jetpack-compose'; export default function LazyRowPadding() { return ( <Host style={{ height: 100 }}> <LazyRow contentPadding={{ start: 16, top: 8, end: 16, bottom: 8 }}> <Text>带内边距的项目 1</Text> <Text>带内边距的项目 2</Text> <Text>带内边距的项目 3</Text> </LazyRow> </Host> ); }
API
import { LazyRow } from '@expo/ui/jetpack-compose';
Component
Type: React.Element<LazyRowProps>
A lazy row component that efficiently displays a horizontally scrolling list.
unionThe horizontal arrangement of items.
Can be a preset string or an object with spacedBy to specify spacing in dp.
Acceptable values are: 'start' | 'end' | 'center' | 'spaceBetween' | 'spaceAround' | 'spaceEvenly' | {
spacedBy: number
}