layui将Json导出为excel

html代码

 <div class="layui-inline">
      <div class="layui-btn layui-btn-primary outputbtn" lay-filter="outputbtn">导出数据</div>
  </div>

需要引入的js(Excel.js)

excel.js

JS代码

layui.use(['laydate', 'laypage', 'layer', 'table', 'carousel', 'upload', 'element', 'slider'], function () {
var laydate = layui.laydate //日期
            , laypage = layui.laypage //分页
            , layer = layui.layer //弹层
            , table = layui.table //表格
            , carousel = layui.carousel //轮播
            , upload = layui.upload //上传
            , element = layui.element //元素操作
            , slider = layui.slider //滑块
            , $ = layui.$
            , excel = layui.excel;//导出表格

 $(".outputbtn").bind("click", function () {
//OutTimeJson就是需要导出的json

            var loadlayer = layer.load(1);
            if (OutTimeJson == "") {
                layer.msg("无数据");
                return false;
            }


            var outdata = [];
            for (var stdata in OutTimeJson.data) {
                outdata.push({
                    OrderId: OutTimeJson.data[stdata].OrderId
                    , StoreName: OutTimeJson.data[stdata].StoreName
                    , OrderType: OutTimeJson.data[stdata].OrderType
                    , StartTime: OutTimeJson.data[stdata].StartTime
                    , SendTime: OutTimeJson.data[stdata].SendTime
                    , EndTime: OutTimeJson.data[stdata].EndTime
                    , Remark: OutTimeJson.data[stdata].Remark
                    , Statusdesc: OutTimeJson.data[stdata].Statusdesc
                    , Transportname: OutTimeJson.data[stdata].Transportname
                    , Transportphone: OutTimeJson.data[stdata].Transportphone
                    , AcceptTime: OutTimeJson.data[stdata].AcceptTime
                    , FetchTime: OutTimeJson.data[stdata].FetchTime
                    , Reason: OutTimeJson.data[stdata].Reason
                    , DeliverType: OutTimeJson.data[stdata].DeliverType

                });
            }
            // 1. 数组头部新增表头
            outdata.unshift({
                OrderId: '订单号'
                , StoreName: '门店名'
                , OrderType: '订单平台'
                , StartTime: '订单开始时间'
                , SendTime: '发货时间'
                , EndTime: '订单结束时间'
                , Remark: '订单备注'
                , Statusdesc: '配送状态'
                , Transportname: '骑手姓名'
                , Transportphone: '骑手电话'
                , AcceptTime: '接单时间'
                , FetchTime: '取货时间'
                , Reason: '异常类型'
                , DeliverType: '配送平台'
            });

            if (outdata.length > 120000) {
                layer.open({
                    title: '导出提示'
                    , content: '数据量太大,超过10万条,不再支持导出。如确实需要导出,请联系电商部。'
                });
                layer.close(loadlayer);
                return false;
            }
            // 2. 如果需要调整顺序,请执行梳理函数
            var data = excel.filterExportData(outdata, [
                'OrderId'
                , 'StoreName'
                , 'OrderType'
                , 'StartTime'
                , 'SendTime'
                , 'EndTime'
                , 'Remark'
                , 'Statusdesc'
                , 'Transportname'
                , 'Transportphone'
                , 'AcceptTime'
                , 'FetchTime'
                , 'Reason'
                , 'DeliverType'

            ]);
            var time = myDate.getFullYear() + "-" + (myDate.getMonth() + 1) + "-" + (myDate.getDate())
            LAY_EXCEL.exportExcel(outdata,"异常订单信息" +'(' + time + ').xlsx', 'xlsx');

            layer.close(loadlayer);
            return false;
        })

})
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

或与且与或非

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值