45 lines
1.3 KiB
Vue
45 lines
1.3 KiB
Vue
<template>
|
|
<PageWrapper title="导出示例" content="可以选择导出格式">
|
|
<BasicTable title="基础表格" :columns="columns" :dataSource="data">
|
|
<template #toolbar>
|
|
<a-button @click="openModal"> 导出 </a-button>
|
|
</template>
|
|
</BasicTable>
|
|
<ExpExcelModal @register="register" @success="defaultHeader" />
|
|
</PageWrapper>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import { defineComponent } from 'vue';
|
|
import { BasicTable } from '/@/components/Table';
|
|
import { jsonToSheetXlsx, ExpExcelModal, ExportModalResult } from '/@/components/Excel';
|
|
import { columns, data } from './data';
|
|
import { useModal } from '/@/components/Modal';
|
|
import { PageWrapper } from '/@/components/Page';
|
|
|
|
export default defineComponent({
|
|
components: { BasicTable, ExpExcelModal, PageWrapper },
|
|
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>
|