跳到主要内容

多选框 Checkbox

多选框

安装使用

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

用法示例

TiCheckbox 示例

单独使用

组件附带文字内容

const App: React.FC = () => {
return (
<>
<TiCheckbox />
<TiCheckbox label="文字内容" />
<TiCheckbox>文字内容</TiCheckbox>
</>
);
}

默认选中状态

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

const App: React.FC = () => {
return (
<>
<TiCheckbox label="默认选中" checked />
<TiCheckbox label="默认选中" defaultChecked />
</>
);
}

禁用多选框点击效果

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

const App: React.FC = () => {
return (
<>
<TiCheckbox label="禁用全部点击效果" disabled />
<TiCheckbox label="禁用文字点击效果" labelDisabled />
</>
);
}

修改多选框的圆角度数

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

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

const App: React.FC = () => {
return (
<>
<TiCheckbox label="方形" shape="square" />
<TiCheckbox label="圆形" shape="circle" />
<TiCheckbox label="自定义角度" shape={4} />
</>
);
}

组件图标设置

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

const App: React.FC = () => {
return (
<>
<TiCheckbox label="默认图标" defaultChecked />
<TiCheckbox label="自定义图标" icon="plus" defaultChecked />
<TiCheckbox label="自定义图标大小" size={64} defaultChecked />
</>
);
}

监听多选框选中状态变化

const App: React.FC = () => {
const handleChange = useCallback((e: CustomEvent<boolean>) => {
console.log(`组件选中状态: ${e.detail ? '选中' : '未选中'}`);
}, []);

return (
<>
<TiCheckbox label="监听切换状态变化" onChange={handleChange} />
</>
);
}

TiCheckboxButton 示例

基本使用

组件附带文字内容

const App: React.FC = () => {
return (
<>
<TiCheckboxButton label="多选按钮" />
<TiCheckboxButton>多选按钮</TiCheckboxButton>
</>
);
}

默认选中状态

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

const App: React.FC = () => {
return (
<>
<TiCheckboxButton label="默认选中" checked />
<TiCheckboxButton label="默认选中" defaultChecked />
</>
);
}

组件内容设置

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

const App: React.FC = () => {
return (
<>
<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>
</>
);
}

改变多选按钮颜色

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

const App: React.FC = () => {
const styles: any = {
"--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%)"
};

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

<div style={styles}>
<TiCheckboxButton label="通过 css 变量更改颜色" />
</div>
</>
);
}

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

const App: React.FC = () => {
const handleChange = useCallback((e: CustomEvent<boolean>) => {
console.log(`组件选中状态: ${e.detail ? '选中' : '未选中'}`);
}, []);

return (
<>
<TiCheckboxButton label="监听切换状态变化" onChange={handleChange} />
</>
);
}

TiCheckboxGroup 示例

基本使用

const App: React.FC = () => {
return (
<>
<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 label="文字内容-3" value="3" />
</TiCheckboxGroup>
</>
);
}

禁用所有多选框点击效果

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

const App: React.FC = () => {
return (
<>
<TiCheckboxGroup disabled>
<TiCheckbox label="禁用整体点击效果-1" value="1" />
<TiCheckbox label="禁用整体点击效果-2" value="2" />
<TiCheckbox label="禁用整体点击效果-3" value="3" />
</TiCheckboxGroup>

<TiCheckboxGroup labelDisabled>
<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>
</>
);
}

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

const App: React.FC = () => {
return (
<>
<TiCheckboxGroup value={["1", "2"]}>
<TiCheckbox label="受控模式-1" value="1" />
<TiCheckbox label="受控模式-2" value="2" />
<TiCheckbox label="受控模式-3" value="3" />
</TiCheckboxGroup>

<TiCheckboxGroup defaultValue={["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 defaultValue={["1", "2"]}>
<TiCheckboxButton label="非受控模式-1" value="1" />
<TiCheckboxButton label="非受控模式-2" value="2" />
<TiCheckboxButton label="非受控模式-3" value="3" />
</TiCheckboxGroup>
</>
);
}

使用 options 创建多选框

此模式只支持创建 TiCheckbox

const App: React.FC = () => {
const options = [
{ value: "a", label: "选项 A" },
{ value: "b", label: "选项 B" },
{ value: "c", label: "选项 C" }
];

return (
<>
<TiCheckboxGroup options={options} />
</>
);
}

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

const App: React.FC = () => {
const handleChange = useCallback((e: CustomEvent<Array<string | number>>) => {
console.log(`组件选中: ${e.detail.join(', ')}`);
}, []);

return (
<>
<TiCheckboxGroup onChange={handleChange} >
<TiCheckbox label="文字内容-1" value="1" />
<TiCheckbox label="文字内容-2" value="2" />
<TiCheckbox label="文字内容-3" value="3" />
</TiCheckboxGroup>

<TiCheckboxGroup onChange={handleChange} >
<TiCheckboxButton label="文字内容-1" value="1" />
<TiCheckboxButton label="文字内容-2" value="2" />
<TiCheckboxButton label="文字内容-3" value="3" />
</TiCheckboxGroup>
</>
);
}

设置最大选中数量

const App: React.FC = () => {
const handleMax = useCallback((e: CustomEvent<never>) => {
console.log("超出最大数量");
}, []);

return (
<>
<TiCheckboxGroup onHandleMax={handleMax} max={2}>
<TiCheckbox label="文字内容-1" value="1" />
<TiCheckbox label="文字内容-2" value="2" />
<TiCheckbox label="文字内容-3" value="3" />
</TiCheckboxGroup>

<TiCheckboxGroup onHandleMax={handleMax} max={2}>
<TiCheckboxButton label="文字内容-1" value="1" />
<TiCheckboxButton label="文字内容-2" value="2" />
<TiCheckboxButton label="文字内容-3" value="3" />
</TiCheckboxGroup>
</>
);
}

TiCheckbox API

属性 Properties

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

事件 Events

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

插槽 Slots

名称说明备注
icon图标插槽icon={false} 或者 icon 不存在时,使用此插槽

可扩展样式名 External Class

名称说明备注
extClass根节点可扩展的类名-
iconClassicon 可扩展的类名-

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指定当前是否选中, 此模式下为控制型组件-
defaultCheckedbooleanfalse初始是否选中, 此模式下为非控制型组件-
disabledbooleanfalse是否禁用-
iconstring-自定义右侧图标名称-
leftIconstring-自定义左侧图标名称-
colorstring-自定义图标颜色-
extStylestring | Record<string, string>-根节点额外扩展样式属性值如果是带单位的话,要带上单位,如:{margin: '10px'}

事件 Events

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

插槽 Slots

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

可扩展样式名 External Class

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

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

Options

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

事件 Events

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

可扩展样式名 External Class

类名说明备注
extClass扩展样式类名-