Blame view

Yi.Vben5.Vue3/playground/src/views/examples/vxe-table/edit-row.vue 2.26 KB
515fceeb   “wangming”   框架初始化
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
  <script lang="ts" setup>
  import type { VxeGridProps } from '#/adapter/vxe-table';
  
  import { Page } from '@vben/common-ui';
  
  import { Button, message } from 'ant-design-vue';
  
  import { useVbenVxeGrid } from '#/adapter/vxe-table';
  import { getExampleTableApi } from '#/api';
  
  interface RowType {
    category: string;
    color: string;
    id: string;
    price: string;
    productName: string;
    releaseDate: string;
  }
  
  const gridOptions: VxeGridProps<RowType> = {
    columns: [
      { title: '序号', type: 'seq', width: 50 },
      { editRender: { name: 'input' }, field: 'category', title: 'Category' },
      { editRender: { name: 'input' }, field: 'color', title: 'Color' },
      {
        editRender: { name: 'input' },
        field: 'productName',
        title: 'Product Name',
      },
      { field: 'price', title: 'Price' },
      { field: 'releaseDate', formatter: 'formatDateTime', title: 'Date' },
      { slots: { default: 'action' }, title: '操作' },
    ],
    editConfig: {
      mode: 'row',
      trigger: 'click',
    },
    height: 'auto',
    pagerConfig: {},
    proxyConfig: {
      ajax: {
        query: async ({ page }) => {
          return await getExampleTableApi({
            page: page.currentPage,
            MaxResultCount: page.pageSize,
          });
        },
      },
    },
    showOverflow: true,
  };
  
  const [Grid, gridApi] = useVbenVxeGrid({ gridOptions });
  
  function hasEditStatus(row: RowType) {
    return gridApi.grid?.isEditByRow(row);
  }
  
  function editRowEvent(row: RowType) {
    gridApi.grid?.setEditRow(row);
  }
  
  async function saveRowEvent(row: RowType) {
    await gridApi.grid?.clearEdit();
  
    gridApi.setLoading(true);
    setTimeout(() => {
      gridApi.setLoading(false);
      message.success({
        content: `保存成功!category=${row.category}`,
      });
    }, 600);
  }
  
  const cancelRowEvent = (_row: RowType) => {
    gridApi.grid?.clearEdit();
  };
  </script>
  
  <template>
    <Page auto-content-height>
      <Grid>
        <template #action="{ row }">
          <template v-if="hasEditStatus(row)">
            <Button type="link" @click="saveRowEvent(row)">保存</Button>
            <Button type="link" @click="cancelRowEvent(row)">取消</Button>
          </template>
          <template v-else>
            <Button type="link" @click="editRowEvent(row)">编辑</Button>
          </template>
        </template>
      </Grid>
    </Page>
  </template>