mirror of
https://github.com/tusen-ai/naive-ui.git
synced 2025-01-24 12:45:18 +08:00
487001d697
.demo.md for component demo .demo-entry.md for demo entry .md for common docs
52 lines
2.1 KiB
Markdown
52 lines
2.1 KiB
Markdown
# 穿梭框 Transfer
|
||
<!--single-column-->
|
||
左、右、左、右...像我这么无聊的人能玩一整天。
|
||
## 演示
|
||
```demo
|
||
basic
|
||
large-data
|
||
size
|
||
filterable
|
||
```
|
||
## V-model
|
||
|Prop|Event|
|
||
|-|-|
|
||
|value|change|
|
||
|
||
## Props
|
||
|名称|类型|默认值|说明|
|
||
|-|-|-|-|
|
||
|theme|`'light' \| 'dark' \| null`|`null`||
|
||
|value|`Array<string \| number>`|`null`||
|
||
|options|`Array<TransferOption>`|`[]`||
|
||
|disabled|`boolean`|`true`||
|
||
|virtual-scroll|`boolean`|`false`|是否在 Transfer 上使用虚拟滚动,如果设成 `true` 它就可以比较快的处理大量数据。(这会关掉 Transfer 的动画)|
|
||
|source-title|`string`|`'源项'`||
|
||
|target-title|`string`|`'目标项'`||
|
||
|filterable|`boolean`|`false`||
|
||
|source-filter-placeholder|`string`|`null`||
|
||
|target-filter-placeholder|`string`|`null`||
|
||
|filter|`(pattern: string, option: TransferOption, from: 'source' \| 'target') => boolean`|一个简单的标签字符串匹配函数||
|
||
|size|`'small' \| 'medium' \| 'large'`|`'medium'`||
|
||
|
||
|
||
### TransferOption Type
|
||
|属性|类型|说明|
|
||
|-|-|-|
|
||
|label|`string`||
|
||
|value|`string \| number`|选项的 value,需要唯一|
|
||
|disabled|`boolean`||
|
||
|
||
## Events
|
||
|名称|参数|说明|
|
||
|-|-|-|
|
||
|change|`(Array<string \| number>)`||
|
||
|
||
## 备注
|
||
当听到同事和我说他要往里面放上千条数据的时候,我是很蛋疼的。贫瘠的想象让我实在难想出为啥非得用这个东西装这么多数据。但是必须承认,大多数情况下还是我考虑得不太周全。
|
||
|
||
几个月之前,我给它弄了个好玩的动画,但是它会触发大量 DOM 的回流。那个时候我根本没考虑还会有人往这里怼这么多数据。虽然我的原则是绝不对样式妥协,但是还是很难跨过浏览器和硬件的限制。这感觉都成了个哲学问题,造一辆车和劳斯莱斯一样舒适,还要和法拉利(或者保时捷、其他什么的)一样快几乎不太可能。
|
||
|
||
(不要说宾利欧陆GT,我觉得那个车长得不太行,它出局了)
|
||
|
||
样式不能妥协,但问题还得解决,所以最后决定搞个加速开关处理大量数据,想快也可以,不放动画就完了。 |