|
1
2
3
|
<template>
<div class="p-4">
<BasicTable @register="registerTable">
|
|
4
5
6
7
8
9
10
11
|
<template #bodyCell="{ column, record }">
<template v-if="column.key === 'action'">
<TableAction
:actions="[
{
label: '编辑',
onClick: handleEdit.bind(null, record),
auth: 'other', // 根据权限控制是否显示: 无权限,不显示
|
|
12
|
},
|
|
13
14
15
16
17
|
{
label: '删除',
icon: 'ic:outline-delete-outline',
onClick: handleDelete.bind(null, record),
auth: 'super', // 根据权限控制是否显示: 有权限,会显示
|
|
18
|
},
|
|
19
20
21
22
23
24
25
26
27
28
29
|
]"
:dropDownActions="[
{
label: '启用',
popConfirm: {
title: '是否启用?',
confirm: handleOpen.bind(null, record),
},
ifShow: (_action) => {
return record.status !== 'enable'; // 根据业务控制是否显示: 非enable状态的不显示启用按钮
},
|
|
30
|
},
|
|
31
32
33
34
35
36
37
38
39
|
{
label: '禁用',
popConfirm: {
title: '是否禁用?',
confirm: handleOpen.bind(null, record),
},
ifShow: () => {
return record.status === 'enable'; // 根据业务控制是否显示: enable状态的显示禁用按钮
},
|
|
40
|
},
|
|
41
42
43
44
45
46
47
48
49
50
|
{
label: '同时控制',
popConfirm: {
title: '是否动态显示?',
confirm: handleOpen.bind(null, record),
},
auth: 'super', // 同时根据权限和业务控制是否显示
ifShow: () => {
return true;
},
|
|
51
|
},
|
|
52
53
54
|
]"
/>
</template>
|
|
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
</template>
</BasicTable>
</div>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
import { BasicTable, useTable, BasicColumn, TableAction } from '/@/components/Table';
import { demoListApi } from '/@/api/demo/table';
const columns: BasicColumn[] = [
{
title: '编号',
dataIndex: 'no',
width: 100,
},
{
title: '姓名',
dataIndex: 'name',
|
|
73
|
width: 200,
|
|
74
75
76
77
78
79
80
|
auth: 'test', // 根据权限控制是否显示: 无权限,不显示
},
{
title: '状态',
dataIndex: 'status',
},
{
|
|
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
|
title: '状态1',
dataIndex: 'status1',
},
{
title: '状态2',
dataIndex: 'status2',
},
{
title: '状态3',
dataIndex: 'status3',
},
{
title: '状态4',
dataIndex: 'status4',
},
{
title: '状态5',
dataIndex: 'status5',
},
{
|
|
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
|
title: '地址',
dataIndex: 'address',
auth: 'super', // 同时根据权限和业务控制是否显示
ifShow: (_column) => {
return true;
},
},
{
title: '开始时间',
dataIndex: 'beginTime',
},
{
title: '结束时间',
dataIndex: 'endTime',
width: 200,
},
];
export default defineComponent({
components: { BasicTable, TableAction },
setup() {
const [registerTable] = useTable({
title: 'TableAction组件及固定列示例',
api: demoListApi,
columns: columns,
bordered: true,
|
|
126
127
128
129
|
rowKey: 'id',
rowSelection: {
type: 'checkbox',
},
|
|
130
131
132
133
|
actionColumn: {
width: 250,
title: 'Action',
dataIndex: 'action',
|
|
134
|
// slots: { customRender: 'action' },
|
|
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
|
},
});
function handleEdit(record: Recordable) {
console.log('点击了编辑', record);
}
function handleDelete(record: Recordable) {
console.log('点击了删除', record);
}
function handleOpen(record: Recordable) {
console.log('点击了启用', record);
}
return {
registerTable,
handleEdit,
handleDelete,
handleOpen,
};
},
});
</script>
|