Skip to content

Select 选择器

使用

当选项过多时,使用下拉菜单展示并选择内容。

TIP

SSR 场景下,您需要将组件包裹在 <client-only></client-only> 之中 (如: Nuxt) 和 SSG (e.g: VitePress).

基础用法

适用广泛的基础单选 v-model 的值为当前被选中的 k-optionvalue 属性值

有禁用选项

k-option 中,设定 disabled 值为 true,即可禁用该选项

禁用状态

禁用整个选择器组件

k-select 设置 disabled属性,则整个选择器不可用。

可清空单选

您可以使用清除图标来清除选择。

k-select 设置 clearable 属性,则可将选择器清空。 需要注意的是,clearable 属性仅适用于单选。

基础多选

多选选择器使用 tag 组件来展示已选中的选项。

k-select 设置 multiple 属性即可启用多选, 此时 v-model 的值为当前选中值所组成的数组。 默认情况下选中值会以 Tag 组件的形式展现, 你也可以设置 collapse-tags 属性将它们合并为一段文字。 您可以使用 collapse-tags-tooltip 属性来启用鼠标悬停折叠文字以显示具体所选值的行为。

自定义模板

你可以自定义如何来渲染每一个选项。

将自定义的 HTML 模板插入 k-optionslot 中即可。

自定义下拉菜单的头部

您可以自定义下拉菜单的头部。

使用slot 自定义内容

自定义下拉菜单的底部

您可以自定义下拉菜单的底部。

使用slot 自定义内容

将选项进行分组

你可以为选项进行分组来区分不同的选项

使用 k-option-group 对备选项进行分组,它的 label 属性为分组名

筛选选项

可以利用筛选功能快速查找选项。

k-select添加filterable属性即可启用搜索功能。 默认情况下,Select 会找出所有 label 属性包含输入值的选项。 如果希望使用其他的搜索逻辑,可以通过传入一个 filter-method 来实现。 filter-method 为一个 Function,它会在输入值发生变化时调用,参数为当前输入值。

远程搜索

输入关键字以从远程服务器中查找数据。

从服务器搜索数据,输入关键字进行查找。为了启用远程搜索,需要将filterableremote设置为true,同时传入一个remote-method。 remote-method为一个Function,它会在输入值发生变化时调用,参数为当前输入值。 需要注意的是,如果 k-option 是通过 v-for 指令渲染出来的,此时需要为k-option 添加 key 属性, 且其值需具有唯一性,比如这个例子中的 item.value

创建新的选项

创建并选中未包含在初始选项中的条目。

通过使用 allow-create 属性,用户可以通过输入框创建新项目。 为了使 allow-create 正常工作, filterable 的值必须为 true。 本例还使用了 default-first-option 属性, 在该属性为 true 的情况下,按下回车就可以选中当前选项列表中的第一个选项,无需使用鼠标或键盘方向键进行定位。

使用值键 value-key 属性

创建并选中未包含在初始选项中的条目。

如果 Select 的绑定值为对象类型,请务必指定 value-key 作为它的唯一性标识。

通过使用 value-key 属性,可以正确处理带有重复label的数据。 这样虽然label 是重复的,但任可通过 id 来确认唯一性。

自定义标签

您可以自定义标签。

将自定义的标签插入 k-selectslot 中即可。 collapse-tags, collapse-tags-tooltip, max-collapse-tags 在此模式下不生效.

自定义加载

修改加载区域内容

API

Select Props

参数名描述类型默认值
model-value/v-model绑定值string | number | boolean | object | array-
multiple是否多选booleanfalse
value-key作为 value 唯一标识的键名,绑定值为对象类型时必填stringvalue
clearable是否显示清除图标booleanfalse
size输入框大小enumbase
placeholder输入框占位文本string-
filterable是否可筛选booleanfalse
allow-create是否允许用户创建新条目,只有当 filterable 设置为 true 时才会生效booleanfalse
filter-method自定义筛选方法Function-
remote是否启用服务端远程搜索booleanfalse
remote-method远程搜索方法Function-
remote-show-suffix远程搜索方法显示后缀图标booleanfalse
loading是否显示加载中状态booleanfa
loading-text加载中状态文本string-
no-match-text无匹配数据时显示的文本,也可以使用empty插槽设置stringNo matching data
no-data-text无选项时显示的文本,也可以使用empty插槽设置stringNo Data
popper-class选择器下拉菜单的自定义类名string''
collapse-tags多选时是否将选中值按文字的形式展示booleanfalse
collapse-tags-tooltip当鼠标悬停于折叠标签的文本时,是否显示所有选中的标签。要使用此属性,collapse-tags属性必须设定为truebooleanfalse
tag-type标签类型enuminfo
reserve-keyword当 multiple和filterable被设置为true时,是否在选中一个选项后保留当前的搜索关键词booleantrue
default-first-option是否在输入框按下回车时,选择第一个匹配项。需配合filterable或remote 使用booleanfalse
teleported是否将下拉列表插入至 body 元素booleantrue
persistent当下拉选择器未被激活并且persistent设置为false,选择器会被删除booleantrue
automatic-dropdown对于不可搜索的输入框,是否在输入框获得焦点后自动弹出选项菜单booleanfalse
clear-icon自定义清除图标string | Component-
fit-input-width是否将下拉选择器的宽度调整为输入框的宽度booleantrue
suffix-icon自定义输入框后缀图标string | ComponentArrowDown
placement下拉列表出现的位置enumbottom-start

Select Events

事件名描述类型
blur输入框失去焦点时触发Function
focus输入框获得焦点时触发Function
change选中值发生变化时触发Function
visible-change下拉列表显示/隐藏时触发Function
clear点击清除图标时触发Function
remove-tag多选模式下移除标签时触发Function

Select Methods

方法名描述类型
blur使输入框失去焦点Function
focus使输入框获得焦点Function

Select Slots

插槽名描述参数
defaultoption组件列表-
header下拉列表头部内容-
footer下拉列表底部内容-
prefixKSelect组件头部内容-
empty无选项时显示的内容-
tag自定义标签内容-
loading自定义loading内容-
label自定义标签内容-

Option Props

参数名描述类型默认值
value选项的值string | number | boolean | object-
label选项的标签,若不设置则默认与value相同string | number-
disabled是否禁用该选项booleanfalse

Option Slots

插槽名描述参数
default默认插槽内容-

OptionGroup Props

参数名描述类型默认值
label分组的名称string-
disabled是否将该分组下所有选项置为禁用booleanfalse

OptionGroup Slots

插槽名描述参数
default默认插槽内容-