Skip to content

Cell 单元格

单元格为列表中的单个展示项。

基本用法

Cell 可以单独使用,也可以和 CellGroup 组合使用。

html
<wd-cell title="标题文字" value="内容" />

<wd-cell-group>
  <wd-cell title="标题文字" value="内容" />
  <wd-cell title="标题文字" label="描述信息" value="内容" />
</wd-cell-group>

图标设置

设置 icon 属性,值可以为 Icon 章节中的图标名,也可以通过 icon 的 slot 自定义图标位置。

自定义图标,如果有多个 cell,需保证所有图标的宽度是一致的且垂直居中。使用 icon 属性且为 Icon 章节的字体图标,则宽度会自动一致且垂直居中;cell 图标的大小是宽 16px,高 16px,large 尺寸图标宽度 18px,高度 18px,距离右侧文字距离 15px。如果使用插槽,可以通过custom-icon-class进行设置。

html
<wd-cell-group>
  <wd-cell title="标题文字" value="内容" icon="setting" />
  <wd-cell title="标题文字" value="内容">
    <template #icon>
      <view class="cell-icon"></view>
    </template>
  </wd-cell>
</wd-cell-group>
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 上设置 titlevalue 属性。

html
<wd-cell-group title="交易管理" value="内容">
  <wd-cell title="标题文字" value="内容" />
  <wd-cell title="标题文字" label="描述信息" value="内容" />
</wd-cell-group>

单元格大小

通过设置 size 修改单元格大小,将 size 设置为 'large' 时左侧标题字号为 16px。

html
<wd-cell size="large" title="标题文字" value="内容" />

展示边框线

wd-cell-group 上设置 border 属性,会给每个 cell 加上边框,最后一个 cell 则不展示边框,其他具有 cell 类型的表单组件也支持边框展示,如 input、picker。

html
<wd-cell-group title="交易管理" border>
  <wd-cell title="标题文字" value="内容" />
  <wd-cell :border="false" title="标题文字" label="这一个cell不想要边框" value="内容" />
  <wd-cell title="标题文字" label="描述信息" value="内容"></wd-cell>
</wd-cell-group>

点击反馈

通过设置 clickable 开启点击反馈,之后可以监听click事件。

html
<wd-toast />
<wd-cell title="标题文字" value="内容" clickable @click="toast" />
typescript
import { useToast } from '@/uni_modules/wot-design-uni'
const toast = useToast()

function showToast() {
  toast.show('点击')
}

页面跳转

通过设置 is-link 属性显示导航箭头和点击态,设置 to 属性,指定跳转地址,可以设置 replace 替换掉历史堆栈中的当前页面。

is-link会默认开启clickable

html
<wd-cell title="帮助与反馈" is-link to="/pages/index/index" />
<wd-cell title="设置" value="内容" is-link to="/pages/button/index" replace></wd-cell>

可以只设置 is-link 用于展示右箭头和点击态。

html
<wd-cell title="帮助与反馈" is-link></wd-cell>

垂直居中

通过设置 center 设置内容垂直居中对齐,默认顶部居中。

html
<wd-cell title="标题文字" value="内容" center></wd-cell>

表单属性 - 必填

设置 required 属性。

html
<wd-cell title="必填" required>
  <wd-rate v-model="rate" change="handleRateChange"></wd-rate>
</wd-cell>
typescript
const rate = ref(0)

function handleRateChange({ value }) {
  console.log(value)
}

表单属性 - 上下结构

设置 vertical 属性。

html
<wd-cell title="上下结构" vertical>
  <wd-slider v-model="slider" change="handleSliderChange"></wd-slider>
</wd-cell>
typescript
const slider = ref('')
function handleSliderChange({ value }) {
  console.log(value)
}

设置左侧宽度

设置 title-width 属性,label 内容超出则会 ... 隐藏,如果有个性化需求,使用插槽实现。

html
<wd-cell title="标题文字" label="这里是文字描述这里是文字描述这里是文字描述" title-width="200px" value="内容" />

内容省略

设置 ellipsis 属性,右侧内容超出时会以省略号显示。

html
<wd-cell title="标题文字" value="这是一段很长很长很长很长很长很长的内容" ellipsis />

自定义内容

cell 提供了 icontitlelabel和默认 value 的插槽。

html
<wd-cell-group>
  <wd-cell title="标题文字" center>
    <wd-button custom-class="custom-value" size="small" plain>按钮</wd-button>
  </wd-cell>
  <wd-cell title="标题文字" center>
    <view class="custom-value" style="height: 32px;">
      <wd-switch v-model="switchValue" change="handleSwitchChange" />
    </view>
  </wd-cell>
  <wd-cell title="标题文字" is-link to="/pages/index/index">
    <view class="custom-text">订购</view>
  </wd-cell>
  <wd-cell>
    <template #title>
      <view>
        <view style="display: inline-block">标题文字</view>
        <view class="end-time">25天后到期</view>
      </view>
    </template>
  </wd-cell>
</wd-cell-group>
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--$LOWEST_VERSION$
label描述信息string---
is-link是否为跳转链接boolean-false-
to跳转地址string---
clickable点击反馈,开启 is-link 时,默认开启此选项boolean-false-
replace跳转时是否替换栈顶页面boolean-false-
size设置单元格大小stringlarge--
title-width设置左侧标题宽度string---
center是否垂直居中,默认顶部居中boolean-false-
required表单属性,必填boolean-false-
marker-side必填标记的位置stringbefore / afterbefore1.12.0
vertical表单属性,上下结构boolean-false-
ellipsis内容省略,右侧内容超出时会以省略号显示boolean-false1.11.0
use-title-slot是否启用title插槽,默认启用,用来解决插槽传递时v-slot和v-if冲突问题boolean-true1.11.0
prop表单域 model 字段名,在使用表单校验功能的情况下,该属性是必填的string---
rules表单验证规则,结合wd-form组件使用FormItemRule []-[]-
border是否展示边框线,优先级高于cell-groupborderboolean---

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-classicon 外部自定义样式-
custom-label-classlabel 外部自定义样式-
custom-value-classvalue 外部自定义样式-
custom-title-classtitle 外部自定义样式-

源代码

文档
组件

Released under the MIT License.

Released under the MIT License.