docs_vue2/one/docs/components/transfer.md
2021-10-18 16:51:48 +08:00

6.4 KiB
Raw Blame History

Transfer 穿梭框

示例

尺寸

可选的尺寸 ui 属性值:s/m

无搜索

自定义搜索

扁平输出树形数据

API

属性

名称 类型 默认值 描述
ui string= - [^ui]
datasource Array<Object> [] [^datasource]
searchable boolean= true 是否允许搜索。
filter function= 见描述 [^filter]
selected Array= [] [^selected]
candidate-placeholder string= - 待选区内搜索框的占位文本。
selected-placeholder string= - 已选区内搜索框的占位文本。
candidate-label string= - “待选项”标题的文字内容。
selected-label string= - “已选项”标题的文字内容。
selected-show-mode string= 'tree' [^selected-show-mode]
keys `string function` 'value'
merge-checked string= keep-all [^merge-checked]

^^^ui 预设样式。

+++枚举值

描述
s 小尺寸样式。
m 中尺寸样式。
+++
^^^

^^^datasource 数据源数组,每个项目类型为 {label, value, disabled, children, ...}

+++字段详情

名称 类型 描述
label string 项目的文字描述。
value string 项目对应的值。
disabled boolean= 项目是否被禁用。
children Array<Object>= 项目的子项目数组,数组项类型同 datasource 数组项。
+++
^^^

^^^filter 搜索过滤函数,签名为 function(from, keyword, item, index, datasource): boolean。返回值为 false 的项目将被从结果中过滤掉。

+++参数详情

名称 类型 描述
from string 搜索来源,可选枚举值:'candidate''selected''candidate' 表示是待选列表触发的搜索,'selected' 表示是已选列表触发的搜索。
keyword string 搜索关键词。
item Object 当前遍历到的数据项。
index number 当前数据项在兄弟项目中的索引。
datasource Array<Object> datasource 属性一致。
+++

+++默认值

import { includes } from 'lodash'

function (keyword, { label }) {
  return includes(label, keyword)
}

+++ ^^^

^^^selected :::badges v-model :::

当前选中的值,是 datasource 中选中项的 value 集合(受 keys 属性影响)。 ^^^

^^^selected-show-mode 选中框中选中项的显示方式。

+++枚举值

描述
tree 以树形结构展示。
flat 以扁平方式展示,数据展开成一维数组。
+++
^^^

^^^keys 自定义获取 datasource 中每一项的 value 值(具备唯一性)。可以用字符串的形式直接指定 datasource 中的哪个属性作为 value,也可以传递一个函数更加灵活地去生成 value 值。

若类型为 function,参数为 (item: Object)itemdatasource 中的一个节点的属性,返回值是添加到 selected 中的值。 ^^^

^^^merge-checked

选中值的合并策略。当某个节点下的所有子节点都被选中时,可以选择只保留父节点、只保留子节点或都保留。

+++枚举值

描述
keep-all 父子节点都会在选中值中。
upwards 尽可能往祖先方向合并选中值。
downwards 尽可能往后代方向合并选中值。
+++
^^^

插槽

名称 描述
candidate 整个待选区。
candidate-head [^candidate-head]
selected-head [^selected-head]
candidate-title 待选区内顶部标题文本区域。作用域参数与 candidate-head 一致。
selected-title 已选区内顶部标题文本区域。作用域参数与 selected-head 一致。
candidate-no-data 数据源没数据时显示的内容。
selected-no-data 没有已选项时显示的内容。
candidate-item [^candidate-item]
selected-item [^selected-item]
candidate-item-label 待选区内每一项的文本区域。作用域参数与 candidate-item 一致。
selected-item-label 已选区内每一项的文本区域。当 selected-show-mode'tree' 时作用域参数与 selected-item 一致。否则该插槽对应每个已选叶子项目的整条路径上的每个节点内容,此时作用域参数与 candidate-item 一致。

^^^candidate-head 待选区内顶部标题区域。

+++作用域参数

名称 类型 描述
count number 待选项的数量。
+++
^^^

^^^selected-head 已选区内顶部标题区域。

+++作用域参数

名称 类型 描述
count number 已选项的数量。
+++
^^^

^^^candidate-item 待选区内的每一项内容。

+++作用域参数

名称 类型 描述
label string 项目的文本描述。
value string 项目的值。
disabled boolean= 项目是否被禁用。
children Array<Object>= 项目的子项目数组,数组项类型同 datasource 数组项。
index number 当前项目在同层级兄弟项中的索引。
depth number 当前项目在树结构中的深度。
+++
^^^

^^^selected-item 已选区内的每一项内容。

+++作用域参数 如果 Transfer 组件的 selected-show-mode'tree',则作用域参数与 candidate-item 一致;如果 selected-show-mode'flat',则作用域参数为:

名称 类型 描述
items Array<Object> 包含从树形结构的根项目到叶子项目的路径。数组项类型与 datasource 项目相同。
index number 当前项目在展开数组中的索引。
+++
^^^

事件

名称 描述
select 切换选择时触发。回调参数为 (selected: Array<string>)selected 为已选项 value 字段集合。

图标

名称 描述
checked 已选状态。
select 待选择。
remove 移除。
expand 收起状态,点击后展开。
collapse 展开状态,点击后收起。
separator selected-show-mode'flat' 时层级间的分隔符。