3.3 KiB
3.3 KiB
title, description, spline, isComponent
| title | description | spline | isComponent |
|---|---|---|---|
| Cascader 级联选择器 | 级联选择器适用于有清晰层级结构的数据集合,用户可以通过逐级查看并选择。 | form | true |
引入
可在 main.ts 或在需要使用的页面或组件中引入。
import TCascader from '@tdesign/uniapp/cascader/cascader.vue';
基础用法
{{ base }}
选项卡风格
{{ theme-tab }}
进阶
带初始值
{{ with-value }}
自定义 keys
{{ keys }}
使用次级标题
{{ with-title }}
选择任意一项
{{ check-strictly }}
API
Cascader Props
| 名称 | 类型 | 默认值 | 描述 | 必传 |
|---|---|---|---|---|
| custom-style | Object | - | 自定义样式 | N |
| check-strictly | Boolean | false | 父子节点选中状态不再关联,可各自选中或取消 | N |
| close-btn | Boolean | true | 关闭按钮 | N |
| keys | Object | - | 用来定义 value / label / children / disabled 在 options 中对应的字段别名。TS 类型:CascaderKeysType type CascaderKeysType = TreeKeysType。通用类型定义。详细类型定义 |
N |
| options | Array | [] | 可选项数据源。TS 类型:Array<CascaderOption> |
N |
| placeholder | String | 选择选项 | 未选中时的提示文案 | N |
| sub-titles | Array | [] | 每级展示的次标题。TS 类型:Array<string> |
N |
| theme | String | step | 展示风格。可选项:step/tab | N |
| title | String | - | 标题 | N |
| value | String / Number | - | 选项值。支持语法糖 v-model:value |
N |
| default-value | String / Number | - | 选项值。非受控属性 | N |
| visible | Boolean | false | 是否展示 | N |
Cascader Events
| 名称 | 参数 | 描述 |
|---|---|---|
| change | (context: { value: string | number, selectedOptions: string[] }) |
值发生变更时触发 |
| close | (context: { trigger: CascaderTriggerSource }) |
关闭时触发。详细类型定义。type CascaderTriggerSource = 'overlay' | 'close-btn' | 'finish' |
| pick | (context: { value: string | number, label: string, index: number, level: number }) |
选择后触发 |
Cascader Slots
| 名称 | 描述 |
|---|---|
| close-btn | 自定义 close-btn 显示内容 |
| header | 头部 |
| middle-content | 中间内容 |
| title | 自定义 title 显示内容 |
CSS Variables
组件提供了下列 CSS 变量,可用于自定义样式。
| 名称 | 默认值 | 描述 |
|---|---|---|
| --td-cascader-active-color | @brand-color | - |
| --td-cascader-bg-color | @bg-color-container | - |
| --td-cascader-border-color | @component-stroke | - |
| --td-cascader-content-height | 78vh | - |
| --td-cascader-disabled-color | @text-color-disabled | - |
| --td-cascader-options-height | calc(100% - @cascader-step-height) | - |
| --td-cascader-options-title-color | @text-color-placeholder | - |
| --td-cascader-step-arrow-color | @text-color-placeholder | - |
| --td-cascader-step-dot-size | 16rpx | - |
| --td-cascader-step-height | 88rpx | - |
| --td-cascader-title-color | @text-color-primary | - |
| --td-cascader-title-font | @font-title-large | - |
| --td-cascader-title-padding | @spacer-2 | - |