跳到主要内容

多选框 Checkbox

多选框

安装使用

{
// 原生小程序
"usingComponents": {
"ti-checkbox-group": "@titian-design/weapp/checkbox-group/index",
"ti-checkbox-button": "@titian-design/weapp/checkbox-button/index",
"ti-checkbox": "@titian-design/weapp/checkbox/index"
},
// titan-cli搭建的项目
"usingComponents": {
"ti-checkbox-group": "platform://titian-mp/ti-checkbox-group",
"ti-checkbox-button": "platform://titian-mp/ti-checkbox-button",
"ti-checkbox": "platform://titian-mp/ti-checkbox"
}
}

用法示例

ti-checkbox 示例

单独使用

组件附带文字内容

<ti-checkbox />
<ti-checkbox label="文字内容" />
<ti-checkbox>文字内容</ti-checkbox>

默认选中状态

当设置 checked 时为受控模式,多选框的选中状态将由使用者控制,当设置 default-checked时为非受控模式,选中状态将由组件内部控制。默认为非受控模式。

<ti-checkbox label="默认非受控模式" />
<ti-checkbox label="默认选中,受控模式" checked />
<ti-checkbox label="默认选中,非受控模式" default-checked />

禁用多选框点击效果

当设置 disabled 时, 组件将禁用组件的图标和文字的点击切换效果,当设置 label-disabled 时将禁用文字的点击效果,实现更细粒的控制。

<ti-checkbox label="禁用全部点击效果" disabled />
<ti-checkbox label="禁用文字点击效果" label-disabled />

修改多选框的圆角度数

多选框可自定义边框角度,支持方形(square)、圆形(circle)和自定义角度,默认为圆形

当自定义角度时,单位为rpx

<ti-checkbox label="方型" shape="square" />
<ti-checkbox label="圆型" shape="circle" />
<ti-checkbox label="自定义角度" shape="{{4}}" />

组件图标设置

多选框支持自定义组件图标, 图标大小,图标颜色等。

<ti-checkbox label="默认图标" default-checked />
<ti-checkbox label="自定义图标大小" size="{{64}}" default-checked />
<ti-checkbox label="自定义图标" icon="plus" default-checked />

监听多选框选中状态变化

<ti-checkbox label="监听切换状态变化" bind:change="handleChange" />

ti-checkbox-button 示例

基本使用

组件附带文字内容

<ti-checkbox-button label="复选按钮文字" />
<ti-checkbox-button>复选按钮文字</ti-checkbox-button>

默认选中状态

当设置 checked 时为受控模式,多选按钮的选中状态将由使用者控制,当设置 default-checked 时为非受控模式,选中状态将由组件内部控制。默认为非受控模式。

<ti-checkbox-button label="默认选中" checked />
<ti-checkbox-button label="默认选中" default-checked />

组件内容设置

多选按钮支持自定义前后内容,图标等。

<ti-checkbox-button label="设置右侧图标" icon="sort-inactive" />
<ti-checkbox-button label="自定义左侧内容">
<ti-image
ext-style="margin-right: 6rpx"
slot="prefix"
width="{{40}}"
radius="{{0}}"
height="{{40}}"
src="https://image-c-dev.weimobwmc.com/qa-On6X/8b97cd488593474ba4a8ccaa3c1a493f.png"
/>
</ti-checkbox-button>
<ti-checkbox-button label="自定义右侧内容">
<ti-image
ext-style="margin-left: 6rpx"
slot="suffix" width="{{40}}"
radius="{{0}}"
height="{{40}}"
src="https://image-c-dev.weimobwmc.com/qa-On6X/8b97cd488593474ba4a8ccaa3c1a493f.png"
/>
</ti-checkbox-button>

改变多选按钮颜色

多选按钮默认根据主题色变化,如需改变按钮颜色可参考下面示例

<ti-checkbox-button label="通过属性更改颜色" color="#2a6ae9" default-checked />
<view class="custom-color">
<ti-checkbox-button label="通过 css 变量更改颜色" default-checked />
</view>

监听多选按钮选中状态变化

<ti-checkbox-button label="监听切换状态变化" bind:change="handleChange" />

ti-checkbox-group 示例

基本使用

<ti-checkbox-group>
<ti-checkbox label="文字内容-1" value="1" />
<ti-checkbox label="文字内容-2" value="2" />
<ti-checkbox label="文字内容-3" value="3" />
</ti-checkbox-group>
<ti-checkbox-group>
<ti-checkbox-button label="文字内容-1" value="1" />
<ti-checkbox-button label="文字内容-2" value="2" />
<ti-checkbox-button label="文字内容-3" value="3" />
</ti-checkbox-group>

禁用所有多选框点击效果

当设置 disabled 时, 子组件将禁用组件的图标和文字的点击切换效果,当设置 label-disabled 时将禁用子组件文字的点击效果,实现更细粒的控制。

<ti-checkbox-group disabled>
<ti-checkbox label="整体禁用点击-1" value="1" />
<ti-checkbox label="整体禁用点击-2" value="2" />
<ti-checkbox label="整体禁用点击-3" value="3" />
</ti-checkbox-group>

<ti-checkbox-group label-disabled>
<ti-checkbox label="文字禁用点击-1" value="1" />
<ti-checkbox label="文字禁用点击-2" value="2" />
<ti-checkbox label="文字禁用点击-3" value="3" />
</ti-checkbox-group>

<ti-checkbox-group disabled>
<ti-checkbox-button label="禁用点击效果-1" value="1" />
<ti-checkbox-button label="禁用点击效果-2" value="2" />
<ti-checkbox-button label="禁用点击效果-3" value="3" />
</ti-checkbox-group>

设置多选框组合中的选中值

<ti-checkbox-group value="{{groupValue}}">
<ti-checkbox label="受控模式-1" value="1" />
<ti-checkbox label="受控模式-2" value="2" />
<ti-checkbox label="受控模式-3" value="3" />
</ti-checkbox-group>

<ti-checkbox-group value="{{groupValue}}">
<ti-checkbox-button label="受控模式-1" value="1" />
<ti-checkbox-button label="受控模式-2" value="2" />
<ti-checkbox-button label="受控模式-3" value="3" />
</ti-checkbox-group>

<ti-checkbox-group default-value="{{groupValue}}">
<ti-checkbox label="非受控模式-1" value="1" />
<ti-checkbox label="非受控模式-2" value="2" />
<ti-checkbox label="非受控模式-3" value="3" />
</ti-checkbox-group>

<ti-checkbox-group default-value="{{groupValue}}">
<ti-checkbox-button label="非受控模式-1" value="1" />
<ti-checkbox-button label="非受控模式-2" value="2" />
<ti-checkbox-button label="非受控模式-3" value="3" />
</ti-checkbox-group>

使用 options 创建多选框

此模式只支持创建 ti-checkbox

<ti-checkbox-group default-value="{{groupValue}}" options="{{options}}" />

监听多选组合中选中状态变化

<ti-checkbox-group bind:change="handleChange">
<ti-checkbox label="监听切换状态变化-1" value="1" />
<ti-checkbox label="监听切换状态变化-2" value="2" />
<ti-checkbox label="监听切换状态变化-3" value="3" />
</ti-checkbox-group>

<ti-checkbox-group bind:change="handleChange">
<ti-checkbox-button label="监听切换状态变化-1" value="1" />
<ti-checkbox-button label="监听切换状态变化-2" value="2" />
<ti-checkbox-button label="监听切换状态变化-3" value="3" />
</ti-checkbox-group>

设置最大选中数量

<ti-checkbox-group bind:handle-max="handleMax" max="{{2}}">
<ti-checkbox label="监听切换状态变化-1" value="1" />
<ti-checkbox label="监听切换状态变化-2" value="2" />
<ti-checkbox label="监听切换状态变化-3" value="3" />
</ti-checkbox-group>
<ti-checkbox-group bind:handle-max="handleMax" max="{{2}}">
<ti-checkbox-button label="监听切换状态变化-1" value="1" />
<ti-checkbox-button label="监听切换状态变化-2" value="2" />
<ti-checkbox-button label="监听切换状态变化-3" value="3" />
</ti-checkbox-group>

ti-checkbox API

属性 Properties

名称类型必填默认值说明备注
labelstring-文字内容-
valuestring-标识 Checkbox 名称-
checkedbooleanfalse指定当前是否选中, 此模式下为控制型组件-
default-checkedbooleanfalse初始是否选中, 此模式下为非控制型组件-
disabledbooleanfalse是否禁用-
label-disabledbooleanfalse文字区域是否禁用-
shapesquare | circle | numbercircle多选框形状-
iconstring-自定义图标名称-
sizenumber-自定义图标尺寸-
colorstring-自定义图标颜色-
ext-stylestring-根节点额外扩展样式-

事件 Events

名称参数列表描述备注
bind:change(e: WechatMiniprogram.CustomEvent<boolean>) => void多选框选中时触发的事件当被 ti-checkbox-group 包裹时,只有 ti-checkbox-groupchange 会被触发

插槽 Slots

名称说明备注
icon图标插槽icon="{{false}}"时,使用此插槽

可扩展样式名 External Class

名称说明备注
ext-class根节点可扩展的类名-
icon-classicon 可扩展的类名-

CSS 变量 CSS Variables

变量默认值说明备注
--checkbox-radiuscalc(var(--base-radius-size, 0px) + 4px)--
--checkbox-padding-v0--
--checkbox-padding-h0--
--checkbox-label-padding-v0--
--checkbox-label-padding-h12rpx--
--checkbox-label-colorvar(--neutral-color-1, #212121)--
--checkbox-directionrow--
--checkbox-icon-colorrgb(@theme-r, @theme-g, @theme-b)--
--checkbox-icon-revert-colorvar(--neutral-color-9, #ffffff)--

ti-checkbox-button API

属性 Properties

名称类型必填默认值说明备注
labelstring-文字内容-
valuestring-标识 Checkbox 名称-
checkedbooleanfalse指定当前是否选中, 此模式下为控制型组件-
default-checkedbooleanfalse初始是否选中, 此模式下为非控制型组件-
disabledbooleanfalse是否禁用-
iconstring-自定义右侧图标名称-
left-iconstring-自定义左侧图标名称-
colorstring-自定义图标颜色-
ext-stylestring-根节点额外扩展样式-

事件 Events

名称参数列表描述备注
bind:change(e: WechatMiniprogram.CustomEvent<boolean>) => void多选框选中时发生的回调当被 ti-checkbox-group 包裹时,只有 ti-checkbox-groupchange 会被触发

插槽 Slots

名称说明备注
prefix自定义文字前面内容-
suffix自定义文字后面内容-

可扩展样式名 External Class

名称说明备注
ext-class根节点可扩展的类名-

CSS 变量 CSS Variables

变量默认值说明备注
--checkbox-button-height56rpx--
--checkbox-button-padding-v0--
--checkbox-button-padding-h12rpx--
--checkbox-button-text-colorvar(--neutral-color-2, #757575)--
--checkbox-button-disabled-text-colorvar(--neutral-color-4, #c4c4c4)--
--checkbox-button-disabled-border-colorrgba(var(--theme-r, 250), var(--theme-g, 44), var(--theme-b, 25), 20%)--
--checkbox-button-bg-colorvar(--neutral-color-7, #f5f5f5)--
--checkbox-button-padding12px 20px--
--checkbox-button-radiusvar(--checkbox-radius, @radius-8)--
--checkbox-button-checked-bg-colorvar(--checkbox-button-checked-color, rgba(var(--theme-r, 250), var(--theme-g, 44), var(--theme-b, 25), 10%))--
--checkbox-button-checked-border-colorvar(--checkbox-button-checked-color, rgba(var(--theme-r, 250), var(--theme-g, 44), var(--theme-b, 25), 40%))--
--checkbox-button-checked-text-colorvar(--checkbox-button-checked-color, rgba(var(--theme-r, 250), var(--theme-g, 44), var(--theme-b, 25), 100%))--

ti-checkbox-group API

属性 Properties

名称类型是否必填默认值说明备注
valueArray<string | number >-用于设置当前选中的值-
default-valueArray<string | number >-默认选中的值-
disabledbooleanfalse指定当前是否禁用-
directionhorizontal | verticalhorizontal排列方向-
shapecircle | squarecircle图标形状,可选值为 circle、square-
label-disabledbooleanfalse是否禁用文本点击效果-
iconstring-自定义图标名称-
optionsArray<Option>-以配置形式设置子元素-
sizenumber-自定义图标尺寸-
colorstring-自定义图标颜色-
maxnumberNumber.MAX_SAFE_INTEGER最大选中数量-
ext-stylestring-根节点额外扩展样式属性值如果是带单位的话,要带上单位,如:{margin: '10px'}

Options

interface Option {
label: string;
value: string;
disabled?: boolean;
}

事件 Events

名称参数列表描述备注
bind:change(e: WechatMiniprogram.CustomEvent<Array<string | number>>) => void多选框选中时发生的回调-
bind:handle-max(e: WechatMiniprogram.CustomEvent<never>) => void达到最大值时发生的回调-

可扩展样式名 External Class

类名说明备注
ext-class扩展样式类名-