hidden.vue 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. <template>
  2. <div class="scope">
  3. <div class="h">
  4. <el-tag size="small" effect="dark">hidden</el-tag>
  5. <span>隐藏/显示</span>
  6. </div>
  7. <div class="c">
  8. <el-button @click="open">预览</el-button>
  9. <demo-code :files="['table/hidden.vue']" />
  10. <!-- 自定义表格组件 -->
  11. <cl-dialog v-model="visible" title="隐藏/显示" width="80%">
  12. <cl-crud ref="Crud">
  13. <!--配置一个 tab -->
  14. <el-tabs v-model="active">
  15. <el-tab-pane label="员工" name="user"></el-tab-pane>
  16. <el-tab-pane label="企业" name="company"></el-tab-pane>
  17. </el-tabs>
  18. <cl-row>
  19. <!-- 使用方法 showColumn 显示 -->
  20. <el-button @click="showColumn('account')">显示账号</el-button>
  21. <!-- 使用方法 hideColumn 隐藏 -->
  22. <el-button @click="hideColumn('account')">隐藏账号</el-button>
  23. </cl-row>
  24. <cl-row>
  25. <cl-table ref="Table"></cl-table>
  26. </cl-row>
  27. <cl-row>
  28. <cl-flex1 />
  29. <cl-pagination />
  30. </cl-row>
  31. </cl-crud>
  32. </cl-dialog>
  33. </div>
  34. <div class="f">
  35. <span class="date">2024-01-01</span>
  36. </div>
  37. </div>
  38. </template>
  39. <script setup lang="ts">
  40. import { useCrud, useTable } from '@cool-vue/crud';
  41. import { computed, ref } from 'vue';
  42. import { useDict } from '/$/dict';
  43. const { dict } = useDict();
  44. // cl-crud 配置
  45. const Crud = useCrud(
  46. {
  47. // 测试数据,移步到 cl-crud 例子查看
  48. service: 'test'
  49. },
  50. app => {
  51. app.refresh();
  52. }
  53. );
  54. const active = ref('user');
  55. // cl-table 配置
  56. const Table = useTable({
  57. autoHeight: false,
  58. contextMenu: ['refresh'],
  59. columns: [
  60. {
  61. label: 'ID',
  62. prop: 'id',
  63. minWidth: 140,
  64. //【很重要】配置 hidden 参数,格式为 boolean 或者 Vue.ComputedRef<boolean>
  65. hidden: computed(() => {
  66. return active.value != 'company';
  67. })
  68. },
  69. {
  70. label: '账号',
  71. prop: 'account',
  72. minWidth: 140,
  73. hidden: true // 默认 false
  74. },
  75. {
  76. label: '姓名',
  77. prop: 'name',
  78. minWidth: 140
  79. },
  80. {
  81. label: '手机号',
  82. prop: 'phone',
  83. minWidth: 140
  84. },
  85. {
  86. label: '工作',
  87. prop: 'occupation',
  88. dict: dict.get('occupation'),
  89. minWidth: 140
  90. },
  91. {
  92. label: '创建时间',
  93. prop: 'createTime',
  94. minWidth: 170,
  95. sortable: 'desc'
  96. }
  97. ]
  98. });
  99. function hideColumn(prop: string) {
  100. Table.value?.hideColumn(prop);
  101. }
  102. function showColumn(prop: string) {
  103. Table.value?.showColumn(prop);
  104. }
  105. const visible = ref(false);
  106. function open() {
  107. visible.value = true;
  108. }
  109. </script>