# Cell 单元格
单元格为列表中的单个展示项。
## 基本用法
`Cell` 可以单独使用,也可以和 `CellGroup` 组合使用。
```html
```
## 图标设置
设置 `icon` 属性,值可以为 Icon 章节中的图标名,也可以通过 icon 的 slot 自定义图标位置。
> 自定义图标,如果有多个 cell,需保证所有图标的宽度是一致的且垂直居中。使用 icon 属性且为 Icon 章节的字体图标,则宽度会自动一致且垂直居中;cell 图标的大小是宽 16px,高 16px,large 尺寸图标宽度 18px,高度 18px,距离右侧文字距离 15px。如果使用插槽,可以通过`custom-icon-class`进行设置。
```html
```
```scss
.cell-icon {
display: block;
box-sizing: border-box;
width: 16px;
height: 16px;
margin-right: 4px;
background: url('https://img10.360buyimg.com/jmadvertisement/jfs/t1/71075/7/3762/1820/5d1f26d1E0d600b9e/a264c901943080ac.png') no-repeat;
background-size: cover;
}
```
## 分组标题
可以在 `cell-group` 上设置 `title` 和 `value` 属性。
```html
```
## 单元格大小
通过设置 `size` 修改单元格大小,将 `size` 设置为 'large' 时左侧标题字号为 16px。
```html
```
## 展示边框线
在 `wd-cell-group` 上设置 `border` 属性,会给每个 cell 加上边框,最后一个 cell 则不展示边框,其他具有 `cell` 类型的表单组件也支持边框展示,如 input、picker。
```html
```
## 点击反馈
通过设置 `clickable` 开启点击反馈,之后可以监听`click`事件。
```html
```
```typescript
import { useToast } from '@/uni_modules/wot-design-uni'
const toast = useToast()
function showToast() {
toast.show('点击')
}
```
## 页面跳转
通过设置 `is-link` 属性显示导航箭头和点击态,设置 `to` 属性,指定跳转地址,可以设置 replace 替换掉历史堆栈中的当前页面。
`is-link`会默认开启`clickable`。
```html
```
可以只设置 `is-link` 用于展示右箭头和点击态。
```html
```
## 垂直居中
通过设置 `center` 设置内容垂直居中对齐,默认顶部居中。
```html
```
## 表单属性 - 必填
设置 `required` 属性。
```html
```
```typescript
const rate = ref(0)
function handleRateChange({ value }) {
console.log(value)
}
```
## 表单属性 - 上下结构
设置 `vertical` 属性。
```html
```
```typescript
const slider = ref('')
function handleSliderChange({ value }) {
console.log(value)
}
```
## 设置左侧宽度
设置 `title-width` 属性,label 内容超出则会 ... 隐藏,如果有个性化需求,使用插槽实现。
```html
```
## 内容省略
设置 `ellipsis` 属性,右侧内容超出时会以省略号显示。
```html
```
## 自定义内容
`cell` 提供了 `icon`、`title`、`label`和默认 value 的插槽。
```html
按钮
订购
标题文字
25天后到期
```
```typescript
const switchValue = ref('')
function handleSwitchChange({ value }) {
console.log(value)
}
```
```scss
.cell-icon {
display: block;
box-sizing: border-box;
padding: 4px 0;
width: 16px;
height: 24px;
margin-right: 4px;
background: url('https://img10.360buyimg.com/jmadvertisement/jfs/t1/71075/7/3762/1820/5d1f26d1E0d600b9e/a264c901943080ac.png') no-repeat;
background-size: cover;
}
:deep(.custom-value) {
position: absolute;
top: 50%;
right: 0;
transform: translate(0, -50%);
white-space: nowrap;
}
.custom-text {
color: #f0883a;
}
.end-time {
display: inline-block;
margin-left: 8px;
border: 1px solid #faa21e;
padding: 0 4px;
font-size: 10px;
color: #faa21e;
}
```
## CellGroup Attributes
| 参数 | 说明 | 类型 | 可选值 | 默认值 | 最低版本 |
| -------- | -------------- | ------- | ------ | ------ | -------- |
| title | 分组标题 | string | - | - | - |
| value | 分组右侧内容 | string | - | - | - |
| border | 是否展示边框线 | boolean | - | - | - |
| use-slot | 分组启用插槽 | boolean | - | false | - |
## Cell Attributes
| 参数 | 说明 | 类型 | 可选值 | 默认值 | 最低版本 |
| ----------- | ------------------------------ | ------- | ------ | ------ | -------- |
| title | 标题 | string | - | - | - |
| value | 右侧内容 | string | - | - | - |
| icon | 图标类名 | string | - | - | - |
| icon-size | 图标大小 | string \| number | - | - | 1.13.0 |
| label | 描述信息 | string | - | - | - |
| is-link | 是否为跳转链接 | boolean | - | false | - |
| to | 跳转地址 | string | - | - | - |
| clickable | 点击反馈,开启 is-link 时,默认开启此选项 | boolean | - | false | - |
| replace | 跳转时是否替换栈顶页面 | boolean | - | false | - |
| size | 设置单元格大小 | string | large | - | - |
| title-width | 设置左侧标题宽度 | string | - | - | - |
| center | 是否垂直居中,默认顶部居中 | boolean | - | false | - |
| required | 表单属性,必填 | boolean | - | false | - |
| marker-side | 必填标记的位置 | string | before / after | before | 1.12.0 |
| vertical | 表单属性,上下结构 | boolean | - | false | - |
| ellipsis | 内容省略,右侧内容超出时会以省略号显示 | boolean | - | false | 1.11.0 |
| use-title-slot | 是否启用title插槽,默认启用,用来解决插槽传递时v-slot和v-if冲突问题 | boolean | - | true | 1.11.0 |
| prop | 表单域 `model` 字段名,在使用表单校验功能的情况下,该属性是必填的 | string | - | - | - |
| rules | 表单验证规则,结合`wd-form`组件使用 | `FormItemRule []` | - | `[]` | - |
| border | 是否展示边框线,优先级高于`cell-group`的`border` | boolean | - | - | - |
### FormItemRule 数据结构
| 键名 | 说明 | 类型 |
| --- | --- | --- |
| required | 是否为必选字段 | `boolean` |
| message | 错误提示文案 | `string` |
| validator | 通过函数进行校验,可以返回一个 `Promise` 来进行异步校验 | `(value, rule) => boolean \| Promise` |
| pattern | 通过正则表达式进行校验,正则无法匹配表示校验不通过 | `RegExp` |
## Cell Events
| 事件名称 | 说明 | 参数 | 最低版本 |
| -------- | ------------------------------------------------ | ---- | -------- |
| click | 当 clickable 或 is-link 为 true 时点击单元格触发 | - | - |
## CellGroup Slot
> CellGroup 必须首先开启`use-slot`,插槽才生效。使用插槽时请通过外部自定义样式类来控制样式。
| name | 说明 | 最低版本 |
| ----- | ------------ | -------- |
| title | 分组标题 | - |
| value | 分组右侧内容 | - |
## Cell Slot
| name | 说明 | 最低版本 |
| ------- | ----------------------------------------- | -------- |
| title | 标题 | - |
| default | 右侧内容,使用时不需要设置 `#default` | - |
| icon | 图标 | - |
| label | 描述信息 | - |
## CellGroup 外部样式类
| 类名 | 说明 | 最低版本 |
| ------------ | ---------- | -------- |
| custom-class | 根节点样式 | - |
## Cell 外部样式类
| 类名 | 说明 | 最低版本 |
| ------------------ | ------------------------------ | -------- |
| custom-class | 根节点样式 | - |
| custom-icon-class | icon 外部自定义样式 | - |
| custom-label-class | label 外部自定义样式 | - |
| custom-value-class | value 外部自定义样式 | - |
| custom-title-class | title 外部自定义样式 | - |