CustomExport.vue 1.1 KB
Newer Older
J
jq 已提交
1 2 3 4 5 6 7
<template>
  <div class="m-4">
    <BasicTable title="基础表格" :columns="columns" :dataSource="data">
      <template #toolbar>
        <a-button @click="openModal">导出</a-button>
      </template>
    </BasicTable>
8
    <ExpExcelModel @register="register" @success="defaultHeader" />
J
jq 已提交
9 10 11 12 13 14
  </div>
</template>

<script lang="ts">
  import { defineComponent } from 'vue';
  import { BasicTable } from '/@/components/Table';
15
  import { jsonToSheetXlsx, ExpExcelModel, ExportModalResult } from '/@/components/Excel';
J
jq 已提交
16 17 18 19
  import { columns, data } from './data';
  import { useModal } from '/@/components/Modal';

  export default defineComponent({
20
    components: { BasicTable, ExpExcelModel },
J
jq 已提交
21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
    setup() {
      function defaultHeader({ filename, bookType }: ExportModalResult) {
        // 默认Object.keys(data[0])作为header
        jsonToSheetXlsx({
          data,
          filename,
          write2excelOpts: {
            bookType,
          },
        });
      }
      const [register, { openModal }] = useModal();

      return {
        defaultHeader,
        columns,
        data,
        register,
        openModal,
      };
    },
  });
</script>