HTML Table导出为excel格式

最近项目中有个需求是将页面写好的表格导出位excel格式,刚开始毫无头绪,经过一番查阅找到了解决办法,废话不多说直接上代码:

const tableToExcel = (() => {
    const uri = 'data:application/vnd.ms-excel;base64,';
    const template =
      '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name><x:WorksheetOptions><x:DisplayGridlines/></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--></head><body><table>{table}</table></body></html>';
    var base64 = (s) => {
      return window.btoa(unescape(encodeURIComponent(s)));
    };
    var format = (s, c) => {
      return s.replace(/{(\w+)}/g, (m, p) => {
        return c[p];
      });
    };
    return (table, name, filename) => {
      if (!table.nodeType) table = document.getElementById(table);
      var ctx = { worksheet: name || 'Worksheet', table: table.innerHTML };

      document.getElementById('dlink').href = uri + base64(format(template, ctx));
      document.getElementById('dlink').download = filename;
      document.getElementById('dlink').click();
    };
  })();

注解: 

页面上设置按钮可以直接点击调用这个函数,函数里面设置了需要导出的格式类型,将表格内容转化为base64编码,然后在导出为excel,具体可以查阅大神文档

关于上面函数中return里面的参数 table name fileName

table: 表格ID

name: excel中sheet页名称

fileName:导出时excel的名称

 

友情提示: 我使用这个方法是在React项目中,所以转化为了ES6的写法,如果使用了antd的表格或者其他UI库的表格可以直接找插件进行下载。

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值