当前位置: 首页 > article >正文

vue表格列表导出excel

你可以通过下面的步骤使用Vue导出Excel表格:

  1. 安装依赖 安装两个依赖包:
npm install --save xlsx file-saver

  1. 创建Excel导出方法
//导出 Excel
exportExcel() {
  // 表格数据
  let data = this.tableData;
  // 转化为工作簿对象
  const workbook = XLSX.utils.book_new();
  // 表头
  const header = [
    '姓名',
    '年龄',
    '性别',
  ];
  // 表头对应的键名
  const keys = [
    'name',
    'age',
    'gender',
  ];
  // 表格数据处理
  const arr = [];
  data.forEach(item => {
    const obj = {};
    keys.forEach(key => {
      obj[key] = item[key];
    });
    arr.push(obj);
  });
  // 创建工作表
  const worksheet = XLSX.utils.json_to_sheet(arr, { header });
  // 将工作表添加到工作簿
  XLSX.utils.book_append_sheet(workbook, worksheet, 'Sheet1');
  // 导出 Excel
  XLSX.writeFile(workbook, 'table.xlsx');
}

  1. 创建导出Excel的按钮
<template>
  <div>
    <table>
      <thead>
        <tr>
          <th>姓名</th>
          <th>年龄</th>
          <th>性别</th>
        </tr>
      </thead>
      <tbody>
        <tr v-for="(item, index) in tableData" :key="index">
          <td>{{item.name}}</td>
          <td>{{item.age}}</td>
          <td>{{item.gender}}</td>
        </tr>
      </tbody>
    </table>
    <button @click="exportExcel">导出 Excel</button>
  </div>
</template>

现在你就可以导出Excel表格了。


http://www.kler.cn/a/107884.html

相关文章:

  • 【面试题】发起一次网络请求,当请求>=1s,立马中断
  • 【软件工程】一篇入门UML建模图(类图)
  • 前端-同源与跨域
  • python高效处理大数据:将Excel10万数据分批插入MySQL数据库的实战代码
  • MYSQL 库,表 基本操作
  • 万字长文分析函数式编程
  • 中文编程开发语言工具系统化教程零基础入门篇和初级1专辑课程已经上线,可以进入轻松学编程
  • 【目标检测】Visdrone数据集和CARPK数据集预处理
  • SQL中的非重复计数(进阶)
  • 项目管理概论:什么是项目、项目管理的重要性、成功的标准包含什么以及相关笔记
  • Vue3响应式对象: ref和reactive
  • C++STL---Vector、List所要掌握的基本知识
  • RGB-T Salient Object Detection via Fusing Multi-Level CNN Features
  • python opencv之图像分割、计算面积
  • [cpp primer随笔] 14. 类的构造函数
  • Winsows QT5.15安装教程——组件务必要选上Sources
  • vue3动态引入图片(:src)
  • k8s中 pod 或节点的资源利用率监控
  • 【HarmonyOS】鸿蒙操作系统架构
  • 【SEC 学习】Vim 的基本使用
  • Proteus仿真--花样流水灯(仿真文件+程序)
  • 驱动day8
  • List 3.5 详解原码、反码、补码
  • 阿里云/腾讯云国际站代理:国际腾讯云的优势
  • Shopee买家通系统全自动化操作简单方便又快速
  • 开发者常用的API汇总,含免费次数