车间能级提升-智能设备管理系统
baoshiwei
2025-04-17 bb79260cbeeac88cfbadc9606eea57002e8945bc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
<script setup lang="ts">
import { ref, watch } from 'vue';
 
import { Space } from 'ant-design-vue';
 
import { useVbenVxeGrid, type VxeGridProps, vxeSortEvent } from '#/adapter/vxe-table';
 
interface Props {
  reqKey: string;
  reqValue: any;
  title?: string;
  listApi: (params: any) => Promise<any>; // 动态API函数
  columns?: VxeGridProps['columns'];
}
const props = defineProps<Props>();
const columns = props?.columns?.filter((i) => i.field !== 'action');
 
const gridOptions: VxeGridProps = {
  size: 'mini',
  checkboxConfig: {
    // 高亮
    highlight: true,
    // 翻页时保留选中状态
    reserve: true
    // 点击行选中
    // trigger: 'row'
  },
  columns,
  height: 'auto',
  keepSource: true,
  pagerConfig: {},
  proxyConfig: {
    ajax: {
      query: async ({ page }, formValues = {}) => {
        const keyName = props.reqKey;
        const keyValue = props.reqValue;
        if (keyName && keyValue) {
          const params = { [keyName]: props.reqValue };
          Object.assign(formValues, params);
        } else {
          // 未传参则查询一个不存在的值
          // const params = { [keyName]: -1 };
          // Object.assign(formValues, params);
          return  false
        }
        return await props.listApi({
          pageNum: page.currentPage,
          pageSize: page.pageSize,
          ...formValues
        });
      }
    }
  },
  rowConfig: {
    isHover: true,
    keyField: 'id'
  },
  sortConfig: {
    // 远程排序
    remote: true,
    // 支持多字段排序 默认关闭
    multiple: true
  },
  id: `basis-sub-table${props.reqValue}`
};
 
const [BasicTable, tableApi] = useVbenVxeGrid({
  gridOptions,
  gridEvents: {
    sortChange: (sortParams) => vxeSortEvent(tableApi, sortParams)
  }
});
 
// 使用 watch 监听 id 的变化
watch(
  () => props.reqValue,
  (newVal, oldVal) => {
    if (newVal !== oldVal && newVal) {
      tableApi.query();
    }
  },
  { immediate: false }
);
/**
 * TODO 后续扩展点击事件
 */
const slotName = ref<string>('equName');
</script>
 
<template>
  <div class="w-full">
    <BasicTable :table-title="title">
      <template #[slotName]="{ row }">
        <Space>
          <span>{{ row[slotName] }}</span>
        </Space>
      </template>
    </BasicTable>
  </div>
</template>