跳到主要内容

多选框 Checkbox

多选框

安装使用

import { TiCheckbox, TiCheckboxGroup, TiCheckboxButton } from '@titian-design/mobile-vue';

用法示例

TiCheckbox 示例

单独使用

组件附带文字内容

<template>
<TiCheckbox />
<TiCheckbox label="文字内容" />
<TiCheckbox>文字内容</TiCheckbox>
</template>

<script lang="ts" setup>
import { TiCheckbox } from '@titian-design/mobile-vue';
</script>

默认选中状态

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

<template>
<TiCheckbox label="默认选中" checked />
<TiCheckbox label="默认选中" default-checked />
</template>

<script lang="ts" setup>
import { TiCheckbox } from '@titian-design/mobile-vue';
</script>

禁用多选框点击效果

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

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

<script lang="ts" setup>
import { TiCheckbox } from '@titian-design/mobile-vue';
</script>

修改多选框的圆角度数

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

当自定义角度时,会自动根据屏幕分辨率调整数字大小!

<template>
<TiCheckbox label="方形" shape="square" />
<TiCheckbox label="圆形" shape="circle" />
<TiCheckbox label="自定义角度" :shape="4" />
</template>

<script lang="ts" setup>
import { TiCheckbox } from '@titian-design/mobile-vue';
</script>

组件图标设置

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

<template>
<TiCheckbox label="默认图标" default-checked />
<TiCheckbox label="自定义图标" icon="plus" default-checked />
<TiCheckbox label="自定义图标大小" :size="64" default-checked />
</template>

<script lang="ts" setup>
import { TiCheckbox } from '@titian-design/mobile-vue';
</script>

监听多选框选中状态变化

<template>
<TiCheckbox label="监听切换状态变化" @change="handleChange" />
</template>

<script lang="ts" setup>
import { TiCheckbox } from '@titian-design/mobile-vue';

const handleChange = (e: CustomEvent<boolean>) => {
console.log(`组件选中状态: ${e.detail ? '选中' : '未选中'}`);
};
</script>

TiCheckboxButton 示例

基本使用

组件附带文字内容

<template>
<TiCheckboxButton label="多选按钮" />
<TiCheckboxButton>多选按钮</TiCheckboxButton>
</template>

<script lang="ts" setup>
import { TiCheckboxButton } from '@titian-design/mobile-vue';
</script>

默认选中状态

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

<template>
<TiCheckboxButton label="默认选中" checked />
<TiCheckboxButton label="默认选中" default-checked />
</template>

<script lang="ts" setup>
import { TiCheckboxButton } from '@titian-design/mobile-vue';
</script>

组件内容设置

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

<template>
<TiCheckboxButton label="设置右侧图标" icon="sort-inactive" />

<TiCheckboxButton label="自定义左侧内容">
<TiImage
slot="prefix"
:width="40"
:radius="0"
:height="40"
src="https://image-c-dev.weimobwmc.com/qa-On6X/8b97cd488593474ba4a8ccaa3c1a493f.png"
/>
</TiCheckboxButton>

<TiCheckboxButton label="自定义右侧内容">
<TiImage
slot="suffix"
:width="40"
:radius="0"
:height="40"
src="https://image-c-dev.weimobwmc.com/qa-On6X/8b97cd488593474ba4a8ccaa3c1a493f.png"
/>
</TiCheckboxButton>
</template>

<script lang="ts" setup>
import { TiCheckboxButton, TiImage } from '@titian-design/mobile-vue';
</script>

改变多选按钮颜色

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

<template>
<TiCheckboxButton label="通过属性更改颜色" color="#2a6ae9" />

<div :style="styles">
<TiCheckboxButton label="通过 css 变量更改颜色" />
</div>
</template>

<script lang="ts" setup>
import { TiCheckboxButton } from '@titian-design/mobile-vue';

const styles: Record<string, string> = {
"--checkbox-button-checked-border-color": "rgba(30, 128, 255, 40%)",
"--checkbox-button-checked-bg-color": "rgba(30, 128, 255, 10%)",
"--checkbox-button-checked-text-color": "rgba(30, 128, 255, 100%)"
};
</script>

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

<template>
<TiCheckboxButton label="监听切换状态变化" @change="handleChange" />
</template>

<script lang="ts" setup>
import { TiCheckboxButton } from '@titian-design/mobile-vue';

const handleChange = (e: CustomEvent<boolean>) => {
console.log(`组件选中状态: ${e.detail ? '选中' : '未选中'}`);
};
</script>

TiCheckboxGroup 示例

基本使用

<template>
<TiCheckboxGroup>
<TiCheckbox label="文字内容-1" value="1" />
<TiCheckbox label="文字内容-2" value="2" />
<TiCheckbox label="文字内容-3" value="3" />
</TiCheckboxGroup>

<TiCheckboxGroup>
<TiCheckboxButton label="文字内容-1" value="1" />
<TiCheckboxButton label="文字内容-2" value="2" />
<TiCheckboxButton
</template>

<script lang="ts" setup>
import { TiCheckboxGroup, TiCheckbox, TiCheckboxButton } from '@titian-design/mobile-vue';
</script>

禁用所有多选框点击效果

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

<template>
<TiCheckboxGroup disabled>
<TiCheckbox label="禁用整体点击效果-1" value="1" />
<TiCheckbox label="禁用整体点击效果-2" value="2" />
<TiCheckbox label="禁用整体点击效果-3" value="3" />
</TiCheckboxGroup>

<TiCheckboxGroup label-disabled>
<TiCheckbox label="禁用文字点击效果-1" value="1" />
<TiCheckbox label="禁用文字点击效果-2" value="2" />
<TiCheckbox label="禁用文字点击效果-3" value="3" />
</TiCheckboxGroup>

<TiCheckboxGroup disabled>
<TiCheckboxButton label="禁用点击效果-1" value="1" />
<TiCheckboxButton label="禁用点击效果-2" value="2" />
<TiCheckboxButton label="禁用点击效果-3" value="3" />
</TiCheckboxGroup>
</template>

<script lang="ts" setup>
import { TiCheckboxGroup, TiCheckbox, TiCheckboxButton } from '@titian-design/mobile-vue';
</script>

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

<template>
<TiCheckboxGroup :value="['1', '2']">
<TiCheckbox label="受控模式-1" value="1" />
<TiCheckbox label="受控模式-2" value="2" />
<TiCheckbox label="受控模式-3" value="3" />
</TiCheckboxGroup>

<TiCheckboxGroup :default-value="['1', '2']">
<TiCheckbox label="非受控模式-1" value="1" />
<TiCheckbox label="非受控模式-2" value="2" />
<TiCheckbox label="非受控模式-3" value="3" />
</TiCheckboxGroup>

<TiCheckboxGroup :value="['1', '2']">
<TiCheckboxButton label="受控模式-1" value="1" />
<TiCheckboxButton label="受控模式-2" value="2" />
<TiCheckboxButton label="受控模式-3" value="3" />
</TiCheckboxGroup>

<TiCheckboxGroup :default-value="['1', '2']">
<TiCheckboxButton label="非受控模式-1" value="1" />
<TiCheckboxButton label="非受控模式-2" value="2" />
<TiCheckboxButton label="非受控模式-3" value="3" />
</TiCheckboxGroup>
</template>

<script lang="ts" setup>
import { TiCheckboxGroup, TiCheckbox, TiCheckboxButton } from '@titian-design/mobile-vue';
</script>

使用 options 创建多选框

此模式只支持创建 TiCheckbox

<template>
<TiCheckboxGroup :options="options" />
</template>

<script lang="ts" setup>
import { TiCheckboxGroup } from '@titian-design/mobile-vue';
const options = [
{ value: "a", label: "选项 A" },
{ value: "b", label: "选项 B" },
{ value: "c", label: "选项 C" }
];
</script>

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

<template>
<TiCheckboxGroup @change="handleChange" >
<TiCheckbox label="文字内容-1" value="1" />
<TiCheckbox label="文字内容-2" value="2" />
<TiCheckbox label="文字内容-3" value="3" />
</TiCheckboxGroup>

<TiCheckboxGroup @change="handleChange" >
<TiCheckboxButton label="文字内容-1" value="1" />
<TiCheckboxButton label="文字内容-2" value="2" />
<TiCheckboxButton label="文字内容-3" value="3" />
</TiCheckboxGroup>
</template>

<script lang="ts" setup>
import { TiCheckboxButton, TiCheckbox, TiCheckboxButton } from '@titian-design/mobile-vue';
const handleChange = (e: CustomEvent<Array<string | number>>) => {
console.log(`组件选中: ${e.detail.join(', ')}`);
};
</script>

设置最大选中数量

<template>
<TiCheckboxGroup :max="2">
<TiCheckbox label="文字内容-1" value="1" />
<TiCheckbox label="文字内容-2" value="2" />
<TiCheckbox label="文字内容-3" value="3" />
</TiCheckboxGroup>

<TiCheckboxGroup :max="2">
<TiCheckboxButton label="文字内容-1" value="1" />
<TiCheckboxButton label="文字内容-2" value="2" />
<TiCheckboxButton label="文字内容-3" value="3" />
</TiCheckboxGroup>
</template>

<script lang="ts" setup>
import { TiCheckboxButton, TiCheckbox, TiCheckboxButton } from '@titian-design/mobile-vue';
</script>

TiCheckbox API

属性 Properties

名称类型必填默认值说明备注
labelstring-文字内容-
valuestring-标识 checkbox 名称-
checkedbooleanfalse指定当前是否选中, 此模式下为控制型组件-
default-checkedbooleanfalse初始是否选中, 此模式下为非控制型组件-
disabledbooleanfalse是否禁用-
label-disabledbooleanfalse文字区域是否禁用-
shapesquare | circle | numbercircle多选框形状-
iconstring-自定义图标名称-
sizenumber-自定义图标尺寸-
colorstring-自定义图标颜色-
ext-stylestring | Record<string, string>-根节点额外扩展样式属性值如果是带单位的话,要带上单位,如:{margin: '10px'}

事件 Events

名称参数列表描述备注
change(e: CustomEvent<boolean>) => void多选框选中时触发的事件当被 TiCheckboxGroup 包裹时,只有 TiCheckboxGroupchange 会被触发

插槽 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-h12px--
--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)--
--checkbox-icon-wrap-padding-v0--
--checkbox-icon-wrap-padding-h0--

TiCheckboxButton API

属性 Properties

名称类型必填默认值说明备注
labelstring-文字内容-
valuestring-标识 Checkbox 名称-
checkedbooleanfalse指定当前是否选中, 此模式下为控制型组件-
default-checkedbooleanfalse初始是否选中, 此模式下为非控制型组件-
disabledbooleanfalse是否禁用-
iconstring-自定义右侧图标名称-
left-iconstring-自定义左侧图标名称-
colorstring-自定义图标颜色-
ext-stylestring | Record<string, string>-根节点额外扩展样式属性值如果是带单位的话,要带上单位,如:{margin: '10px'}

事件 Events

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

插槽 Slots

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

可扩展样式名 External Class

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

CSS 变量 CSS Variables

变量默认值说明备注
--checkbox-button-height56px--
--checkbox-button-padding-v0--
--checkbox-button-padding-h12px--
--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%))--

TiCheckboxGroup 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 | Record<string, string>-根节点额外扩展样式属性值如果是带单位的话,要带上单位,如:{margin: '10px'}

Options

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

事件 Events

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

可扩展样式名 External Class

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