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
| <script lang="ts" setup>
| import type { VxeGridProps } from '#/adapter/vxe-table';
|
| import { onMounted } from 'vue';
|
| import { Page } from '@vben/common-ui';
|
| import { useVbenVxeGrid } from '#/adapter/vxe-table';
|
| interface RowType {
| id: number;
| name: string;
| role: string;
| sex: string;
| }
|
| const gridOptions: VxeGridProps<RowType> = {
| columns: [
| { type: 'seq', width: 70 },
| { field: 'name', title: 'Name' },
| { field: 'role', title: 'Role' },
| { field: 'sex', title: 'Sex' },
| ],
| data: [],
| height: 'auto',
| pagerConfig: {
| enabled: false,
| },
| scrollY: {
| enabled: true,
| gt: 0,
| },
| showOverflow: true,
| };
|
| const [Grid, gridApi] = useVbenVxeGrid({ gridOptions });
|
| // 模拟行数据
| const loadList = (size = 200) => {
| try {
| const dataList: RowType[] = [];
| for (let i = 0; i < size; i++) {
| dataList.push({
| id: 10_000 + i,
| name: `Test${i}`,
| role: 'Developer',
| sex: '男',
| });
| }
| gridApi.setGridOptions({ data: dataList });
| } catch (error) {
| console.error('Failed to load data:', error);
| // Implement user-friendly error handling
| }
| };
|
| onMounted(() => {
| loadList(1000);
| });
| </script>
|
| <template>
| <Page auto-content-height>
| <Grid />
| </Page>
| </template>
|
|