# Transfer 穿梭框 ## 示例 ### 尺寸 可选的尺寸 `ui` 属性值:`s`/`m`。 [[ demo src="/demo/transfer/size.vue" ]] ### 无搜索 [[ demo src="/demo/transfer/no-search.vue" ]] ### 自定义搜索 [[ demo src="/demo/transfer/custom-search.vue" ]] ### 扁平输出树形数据 [[ demo src="/demo/transfer/flat.vue" ]] ## API ### 属性 | 名称 | 类型 | 默认值 | 描述 | | -- | -- | -- | -- | | `ui` | `string=` | - | [^ui] | | `datasource` | `Array` | `[]` | [^datasource] | | `searchable` | `boolean` | `true` | 是否允许搜索。 | | `filter` | `function` | 见描述 | [^filter] | | `selected` | `Array` | `[]` | [^selected] | | `candidate-placeholder` | `string` | - | 待选区内搜索框的占位文本。 | | `selected-placeholder` | `string` | - | 已选区内搜索框的占位文本。 | | `selected-show-mode` | `string` | `'tree'` | [^selected-show-mode] | | `keys` | `string|function` | `'value'` | [^keys] | | `merge-checked` | `string` | `keep-all` | [^merge-checked] | ^^^ui 预设样式。 +++枚举值 | 值 | 描述 | | -- | -- | | `s` | 小尺寸样式。 | | `m` | 中尺寸样式。 | +++ ^^^ ^^^datasource 数据源数组,每个项目类型为 `{label, value, disabled, children, ...}`。 +++字段详情 | 名称 | 类型 | 描述 | | -- | -- | -- | | `label` | `string` | 项目的文字描述。 | | `value` | `string` | 项目对应的值。 | | `disabled` | `boolean=` | 项目是否被禁用。 | | `children` | `Array=` | 项目的子项目数组,数组项类型同 `datasource` 数组项。 | +++ ^^^ ^^^filter 搜索过滤函数,签名为 `function(from, keyword, item, index, datasource): boolean`。返回值为 `false` 的项目将被从结果中过滤掉。 +++参数详情 | 名称 | 类型 | 描述 | | -- | -- | -- | | `from` | `string` | 搜索来源,可选枚举值:`'candidate'`、`'selected'`。`'candidate'` 表示是备选列表触发的搜索,`'selected'` 表示是已选列表触发的搜索。 | | `keyword` | `string` | 搜索关键词。 | | `item` | `Object` | 当前遍历到的数据项。 | | `index` | `number` | 当前数据项在兄弟项目中的索引。 | | `datasource` | `Array` | 与 `datasource` 属性一致。 | +++ +++默认值 ```js 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)`,`item` 是 `datasource` 中的一个节点的属性,返回值是添加到 `selected` 中的值。 ^^^ ^^^merge-checked 选中值的合并策略。 +++枚举值 | 值 | 描述 | | -- | -- | | `keep-all` | 父子节点都会在选中值中。 | | `upwards` | 尽可能往祖先方向合并选中值。 | | `downwards` | 尽可能往后代方向合并选中值。 | +++ ^^^ ### 插槽 | 名称 | 描述 | | -- | -- | | `candidate-head` | 待选区内顶部标题区域。 | | `selected-head` | 已选区内顶部标题区域。 | | `candidate-title` | 待选区内顶部标题文本区域。 | | `selected-title` | 已选区内顶部标题文本区域。 | | `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-item 待选区内的每一项内容。 +++作用域参数 | 名称 | 类型 | 描述 | | -- | -- | -- | | `label` | `string` | 项目的文本描述。 | | `value` | `string` | 项目的值。 | | `disabled` | `boolean=` | 项目是否被禁用。 | | `children` | `Array=` | 项目的子项目数组,数组项类型同 `datasource` 数组项。 | | `index` | `number` | 当前项目在同层级兄弟项中的索引。 | | `depth` | `number` | 当前项目在树结构中的深度。 | +++ ^^^ ^^^selected-item 已选区内的每一项内容。 +++作用域参数 如果 `Transfer` 组件的 `selected-show-mode` 为 `'tree'`,则作用域参数与 `candidate-item` 一致;如果 `selected-show-mode` 为 `'flat'`,则作用域参数为: | 名称 | 类型 | 描述 | | -- | -- | -- | | `items` | `Array` | 包含从树形结构的根项目到叶子项目的路径。数组项类型与 `datasource` 项目相同。 | | `index` | `number` | 当前项目在展开数组中的索引。 | +++ ^^^ ### 事件 | 名称 | 描述 | | -- | -- | | `select` | 切换选择时触发。回调参数为 `(selected: Array)`。`selected` 为已选项 `value` 字段集合。 | ### 图标 | 名称 | 描述 | | -- | -- | | `checked` | 已选状态。 | | `select` | 待选择。 | | `remove` | 移除。 | | `expand` | 收起状态,点击后展开。 | | `collapse` | 展开状态,点击后收起。 | | `separator` | 当 `selected-show-mode` 为 `'flat'` 时层级间的分隔符。 |