mirror of
https://github.com/tusen-ai/naive-ui.git
synced 2025-01-24 12:45:18 +08:00
2.0 KiB
2.0 KiB
穿梭框 Transfer
左、右、左、右...像我这么无聊的人能玩一整天。
例子
basic
large-data
filterable
V-model
Prop | Event |
---|---|
value | change |
Props
名称 | 类型 | 默认值 | 说明 |
---|---|---|---|
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 |
一个简单的标签字符串匹配函数 |
TransferOption Type
属性 | 类型 | 说明 |
---|---|---|
label | string |
|
value | string | number |
选项的 value,需要唯一 |
disabled | boolean |
Events
名称 | 参数 | 说明 |
---|---|---|
change | (Array<string | number>) |
备注
当听到同事和我说他要往里面放上千条数据的时候,我是很蛋疼的。贫瘠的想象让我实在难想出为啥非得用这个东西装这么多数据。但是必须承认,大多数情况下还是我考虑得不太周全。
几个月之前,我给它弄了个好玩的动画,但是它会触发大量 DOM 的回流。那个时候我根本没考虑还会有人往这里怼这么多数据。虽然我的原则是绝不对样式妥协,但是还是很难跨过浏览器和硬件的限制。这感觉都成了个哲学问题,造一辆车和劳斯莱斯一样舒适,还要和法拉利(或者保时捷、其他什么的)一样快几乎不太可能。
(不要说宾利欧陆GT,我觉得那个车长得不太行,它出局了)
样式不能妥协,但问题还得解决,所以最后决定搞个加速开关处理大量数据,想快也可以,不放动画就完了。