vue+elementui 导出table为xlsx表格


第一步:安装所需要的的依赖模块

cnpm i file-saver --save  
cnpm i xlsx --save

 

第二步:在需要导出的页面引入以下两个模块

import FileSaver from "file-saver";
import XLSX from "xlsx";

 

第三步:给table添加一个Id

<el-table id="table" :data="tableData" style="width: 100%">
  <el-table-column prop="date" label="日期" width="180"></el-table-column>
  <el-table-column prop="name" label="姓名"  width="180"></el-table-column>
  <el-table-column prop="address" label="地址"></el-table-column>
</el-table>

<button @click="exportExcel">导出数据</button>

 

第四部分:js

  exportExcel() {
      var xlsxParam = { raw: true }; // 导出的内容只做解析,不进行格式转换(添加此行代码表格中的百分比就不会再导出的时候被转换成小数点)
      let wb = XLSX.utils.table_to_book(
        document.querySelector("#table"),
        xlsxParam
      );
      let wbout = XLSX.write(wb, {
        bookType: "xlsx",
        bookSST: true,
        type: "array"
      });
      // 获取当前的时间戳,用来当文件名
      let time = new Date().getTime();
      try {
        FileSaver.saveAs(
          new Blob([wbout], { type: "application/octet-stream" }),
          `${time}.xlsx`
        ); //${time}是自己导出文件时的命名,随意
      } catch (e) {
        if (typeof console !== "undefined") console.log(e, wbout);
      }
      return wbout;
    },

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM