使用layui把数据以Excel格式导出

昨天领导让我给页面加一个数据导出, 开始我以为是本页导出,我就加一个layui自带的,结果告诉我不行,要导出所有的数据,而且不是页面展示的那个表格的,我就试试

引入layui的JS和CSS就不说了直接来干货。

首先获取数据不说了ajax,导出Excel先看官网给的demo

table.exportFile(['名字','性别','年龄'], [
  ['张三','男','20'],
  ['李四','女','18'],
  ['王五','女','19']
], 'csv'); //默认导出 csv,也可以为:xls

我们会发现按照这个demo做下去我们没有办法定义导出表格的名字,所有的表格都是table_.xls。所以我就进table.js里面看了一下源码,发现 table.exportFile函数里面是这么一段代码来设置名字

alink.download = (config.title || 'table_'+ (config.index || '')) + '.' + type;

于是我就把它给改成了

 alink.download =name + '.' + type;

同时在函数前面增加了一个参数

table.exportFile = function(id, data, type)

改为了

table.exportFile = function(id, data, type,name)

保存之后我们就可以使用ajax获取到的动态数据拿到data,并把data放到函数中导出,

layui.use(['layer','admin','table'], function () {
            var $ = layui.$, admin = layui.admin,layer=layui.layer,table = layui.table;          
                admin.req({
                    url: 你获取数据的URL,
                    async: false,
                    success: function (res) {
                        var cons=new Array();
                        var dat=res.data;
                        for (  i in dat){
                            cons.push(dat[i]);
                        }
                        table.exportFile([' 表头',' 表头',' 表头',' 表头',' 表头',' 表头'], cons , 'xls',name);
                    }
                });
         
        });
这里有两点需要注意:

1.如果你的data是一个对象的集合,必须新建一个数组,通过循环把对象放到数组,不能直接把data放到里面,不然你导出来的是object不是具体值。
2.你的标题要和你导出对象的每个字段对应,你导出来的顺序需要比对一下。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值