UNPKG

@uiw/react-native

Version:
151 lines (107 loc) 4.86 kB
Grid 宫格 --- 在水平和垂直方向,将布局切分成若干等大的区块,也可以使用 `List` 组件支持列显示的特性,展示宫格,同时支持下来刷新等特性。 ### 基础示例 ```jsx mdx:preview&background=#bebebe29 import { Grid, Icon } from '@uiw/react-native'; import React from "react" const data = Array.from(new Array(10)).map((_val, i) => { return { icon: <Icon name="heart-on" color="red" />, text: `${i}`} }); function Demo() { return ( <Grid data={data} /> ); } export default Demo ``` ### 自定义列数 ```jsx mdx:preview&background=#bebebe29 import { Grid, Icon } from '@uiw/react-native'; import React from "react" const data = Array.from(new Array(10)).map((_val, i) => { return { icon: <Icon name="heart-on" color="red" />, text: `${i}`} }); function Demo() { return ( <Grid data={data} columns='6'/> ); } export default Demo ``` ### 是否需要间隔线 ```jsx mdx:preview&background=#bebebe29 import { Grid, Icon } from '@uiw/react-native'; import React from "react" const data = Array.from(new Array(24)).map((_val, i) => { return { icon: <Icon name="heart-on" color="red" />, text: `${i}`} }); function Demo() { return ( <Grid data={data} columns='6' hasLine={false}/> ); } export default Demo ``` ### 自定义icon ```jsx mdx:preview&background=#bebebe29 import { Text, View } from 'react-native'; import { Grid } from '@uiw/react-native'; import React from "react" const uri = ''; const data = Array.from(new Array(7)).map((_val, i) => ({ icon: uri, text: `Name${i}`, })); function Demo() { return ( <Grid data={data} /> ); } export default Demo ``` ### 自定义单元格 ```jsx mdx:preview&background=#bebebe29 import { Text, View } from 'react-native'; import { Grid, Icon } from '@uiw/react-native'; import React from "react" const data = Array.from(new Array(7)).map((_val, i) => ({ icon: <Icon name="apple" color="red" />, text: `Name${i}`, })); function Demo() { return ( <Grid data={data} renderItem={(data, index, rowNum) => { console.log('->', data, index, rowNum) return ( <View style={{width: 100}}> {data.icon} <Text>{data.text}</Text> </View> ) }} /> ); } export default Demo ``` ### Props | 参数 | 说明 | 类型 | 默认值 | |------|------|-----|------| | data | 菜单数据,`icon` 可以是 `ReactNode` 或者 `uri` | `ItemData[]` | - | | columns | 列数 | `number` | 4 | | hasLine | 是否有间隔线 | `boolean` | true | | itemStyle | 单元格样式 | `StyleProp<ViewStyle>` | - | | textStyle | 单元格文本样式 | `StyleProp<TextStyle & ViewStyle>` | - | | iconStyle | 图片样式,可设置图片/图标尺寸 | `StyleProp<ImageStyle & TextStyle & ViewStyle>` | - | | renderItem | 自定义单元格 | `(data: ItemData, index: number, row: number) => React.ReactNode` | - | | onPress | 点击宫格回调函数 | `(data: ItemData, index: number, row: number, event: GestureResponderEvent) => void` | - | ### ItemData | 参数 | 说明 | 类型 | 默认值 | |------|------|-----|------| | text | 显示文字 | `React.ReactNode` | - | | icon | 图标 | `React.ReactNode` | - |