TabsTransfer 组合穿梭器

穿梭器(Transfer)的基础上扩充了左边的展示形式,支持 Tabs 的形式展示。对应的 options 的顶级数据,顶层 options 的成员支持 selectMode 配置这个 tab 下面的选项怎么展示。title 可以配置 tab 的标题。

```schema: scope=”body” { “type”: “form”, “api”: “/api/mock2/form/saveForm”, “body”: [ { “label”: “组合穿梭器”, “type”: “tabs-transfer”, “name”: “a”, “sortable”: true, “selectMode”: “tree”, “options”: [ { “label”: “成员”, “selectMode”: “tree”, “searchable”: true, “children”: [ { “label”: “法师”, “children”: [ { “label”: “诸葛亮”, “value”: “zhugeliang” } ] }, { “label”: “战士”, “children”: [ { “label”: “曹操”, “value”: “caocao” }, { “label”: “钟无艳”, “value”: “zhongwuyan” } ] }, { “label”: “打野”, “children”: [ { “label”: “李白”, “value”: “libai” }, { “label”: “韩信”, “value”: “hanxin” }, { “label”: “云中君”, “value”: “yunzhongjun” } ] } ] }, { “label”: “用户”, “selectMode”: “chained”, “children”: [ { “label”: “法师”, “children”: [ { “label”: “诸葛亮”, “value”: “zhugeliang2” } ] }, { “label”: “战士”, “children”: [ { “label”: “曹操”, “value”: “caocao2” }, { “label”: “钟无艳”, “value”: “zhongwuyan2” } ] }, { “label”: “打野”, “children”: [ { “label”: “李白”, “value”: “libai2” }, { “label”: “韩信”, “value”: “hanxin2” }, { “label”: “云中君”, “value”: “yunzhongjun2” } ] } ] } ] } ] }

  1. ## 自定义选项展示
  2. ```schema: scope="body"
  3. {
  4. "type": "form",
  5. "api": "/api/mock2/form/saveForm",
  6. "body": [
  7. {
  8. "label": "组合穿梭器",
  9. "type": "tabs-transfer",
  10. "name": "a",
  11. "sortable": true,
  12. "selectMode": "tree",
  13. "menuTpl": "<div class='flex justify-between'><span>${label}</span><span class='text-muted m-r text-sm'>${tag}</span></div>",
  14. "valueTpl": "${label}(${value})",
  15. "options": [
  16. {
  17. "label": "成员",
  18. "selectMode": "list",
  19. "searchable": true,
  20. "children": [
  21. {
  22. "label": "诸葛亮",
  23. "value": "zhugeliang",
  24. "tag": "法师",
  25. },
  26. {
  27. "label": "曹操",
  28. "value": "caocao",
  29. "tag": "战士",
  30. },
  31. {
  32. "label": "钟无艳",
  33. "value": "zhongwuyan",
  34. "tag": "战士",
  35. },
  36. {
  37. "label": "李白",
  38. "value": "libai",
  39. "tag": "打野"
  40. },
  41. {
  42. "label": "韩信",
  43. "value": "hanxin",
  44. "tag": "打野"
  45. },
  46. {
  47. "label": "云中君",
  48. "value": "yunzhongjun",
  49. "tag": "打野"
  50. }
  51. ]
  52. },
  53. {
  54. "label": "用户",
  55. "selectMode": "list",
  56. "children": [
  57. {
  58. "label": "诸葛亮",
  59. "value": "zhugeliang",
  60. "tag": "法师",
  61. },
  62. {
  63. "label": "曹操",
  64. "value": "caocao",
  65. "tag": "战士",
  66. },
  67. {
  68. "label": "钟无艳",
  69. "value": "zhongwuyan",
  70. "tag": "战士",
  71. },
  72. {
  73. "label": "李白",
  74. "value": "libai",
  75. "tag": "打野"
  76. },
  77. {
  78. "label": "韩信",
  79. "value": "hanxin",
  80. "tag": "打野"
  81. },
  82. {
  83. "label": "云中君",
  84. "value": "yunzhongjun",
  85. "tag": "打野"
  86. }
  87. ]
  88. }
  89. ]
  90. }
  91. ]
  92. }

数据懒加载

schema: scope="body" { "type": "form", "api": "/api/mock2/form/saveForm", "body": [ { "label": "组合穿梭器", "type": "tabs-transfer", "name": "a", "sortable": true, "selectMode": "tree", "options": [ { "label": "成员", "selectMode": "associated", "searchable": true, "leftMode": "tree", "children": [ { ref: "user", "children": [ { "label": "诸葛亮", "value": "zhugeliang2" }, { "label": "上官婉儿", "value": "shangguan" } ] }, { "ref": "a", "children": [ { "label": "A-1", "value": "a1" }, { "label": "A-2", "value": "a2" } ] }, { "ref": "b", "children": [ { "label": "B-1", "value": "b1" } ] }, { "ref": "c", "children": [ { "label": "C-1", "value": "c1" } ] }, { "ref": "d", "children": [ { "label": "D-1", "value": "d1" } ] }, { "ref": "e", "children": [ { "label": "E-1", "value": "e1" }, { "label": "E-2", "value": "e2" } ] } ], "leftOptions": [ { "defer": true, "deferApi": "/api/mock2/form/getOptions", "label": "DEFER" }, { "label": "法师", "value": "user" } ] }, { "label": "用户", "selectMode": "chained", "children": [ { "label": "法师", "children": [ { "label": "诸葛亮", "value": "zhugeliang2" } ] }, { "label": "战士", "children": [ { "label": "曹操", "value": "caocao2" }, { "label": "钟无艳", "value": "zhongwuyan2" } ] }, { "label": "打野", "children": [ { "label": "李白", "value": "libai2" }, { "label": "韩信", "value": "hanxin2" }, { "label": "云中君", "value": "yunzhongjun2" } ] } ] } ] } ] }

属性表

更多配置请参考穿梭器(Transfer)

事件表

当前组件会对外派发以下事件,可以通过onEvent来监听这些事件,并通过actions来配置执行的动作,在actions中可以通过event.data.xxx事件参数变量来获取事件产生的数据,详细请查看事件动作

事件名称 事件参数 说明
change event.data.value: string 选中值 选中值变化时触发
tab-change event.data.key: number 当前激活的选项卡索引 选项卡切换时触发

动作表

当前组件对外暴露以下特性动作,其他组件可以通过指定actionType: 动作名称componentId: 该组件id来触发这些动作,动作配置可以通过args: {动作配置项名称: xxx}来配置具体的参数,详细请查看事件动作

动作名称 动作配置 说明
clear - 清空
reset - 将值重置为resetValue,若没有配置resetValue,则清空
selectAll - 全选
changeTabKey activeKey: number 选中的 Tab 修改当前选中 tab,来选择其他选项
setValue value: string 更新的值 更新数据,多值用,分隔