• vue3 导出Excel TypeScript


    npm install xlsx

    1. import * as XLSX from 'xlsx';
    2. /**
    3. * 导出到Excel
    4. * @param data - 用于导出的表头为属性的数组 例如:[{姓名: "123", 住址: "456"}]
    5. * @param fileName - 导出文件命名
    6. * @param sheetName - 指定sheet
    7. */
    8. export default (data: any[], fileName = 'fileName.xlsx', sheetName = 'sheet1') => {
    9. const jsonWorkSheet = XLSX.utils.json_to_sheet(data);
    10. const workBook = {
    11. SheetNames: [sheetName], // 指定有序 sheet 的 name
    12. Sheets: {
    13. [sheetName]: jsonWorkSheet // 表格数据内容
    14. }
    15. };
    16. return XLSX.writeFile(workBook, fileName); // 向文件系统写出文件
    17. };
    1. import Export2Excel from '@/utils/Export2Excel';
    2. const tableData = reactive<TableType[]>([]);
    3. const tableColumns: DataTableColumns<TableType> = [
    4. {
    5. title: '姓名',
    6. key: 'name'
    7. },
    8. {
    9. title: '住址',
    10. key: 'address'
    11. }
    12. ]
    13. function exportExcel(){
    14. // 将tableColumns转化为 { name:'姓名', address: '住址' }
    15. const excelKeyToName: { [x: string]: string } = {};
    16. tableColumns.forEach(v => {
    17. excelKeyToName[v.key] = v.title;
    18. });
    19. // 将tableData转化为 [{ '姓名': '123', '住址': '456' }]
    20. const data = tableData.map(item => {
    21. const newItem: { [x: string]: string | { pageindex: number; pagesize: number } | undefined } = {};
    22. Object.keys(item).forEach(key => {
    23. if (excelKeyToName[key]) {
    24. newItem[excelKeyToName[key]] = item[key as keyof TableType];
    25. }
    26. });
    27. return newItem;
    28. });
    29. // 使用导出的方法
    30. Export2Excel(data, '导出.xlsx');
    31. }

    参考滑动验证页面

  • 相关阅读:
    基于燃压缩空气储能系统的零碳微能源互联网优化调度(Matlab代码实现)
    力扣题库3.无重复字符的最长子串
    thymeleaf
    [极客大挑战 2019]BabySQL
    shiro实现自定义Reaml
    【jmeter 5.5】 完全手册
    一、Java语言简介
    基于SpringBoot和PostGIS的世界各国邻国可视化实践
    PosgreSQL函数验证身份证
    Hive学习笔记2
  • 原文地址:https://blog.csdn.net/xichi_12396/article/details/132868672