@uiw/react-native
Version:
UIW for React Native
151 lines (107 loc) • 4.86 kB
Markdown
Grid 宫格
---
在水平和垂直方向,将布局切分成若干等大的区块,也可以使用 `List` 组件支持列显示的特性,展示宫格,同时支持下来刷新等特性。
```jsx mdx:preview&background=
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=
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=
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
```
```jsx mdx:preview&background=
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=
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
```
| 参数 | 说明 | 类型 | 默认值 |
|------|------|-----|------|
| 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` | - |
| 参数 | 说明 | 类型 | 默认值 |
|------|------|-----|------|
| text | 显示文字 | `React.ReactNode` | - |
| icon | 图标 | `React.ReactNode` | - |