• JS 使用xlsx.core.js 进行数据导出到excel(两种方法)


    欧巴酱 2019-07-30 15:46:46 1469 收藏
    版权
    使用前都需导入 xlsx.core.js 等系列组件;

    1.使用table_to_sheet():

    var ws = XLSX.utils.table_to_sheet(document.getElementById("conTable"));

    var wb = new XLSX.utils.book_new();
    XLSX.utils.book_append_sheet(wb, ws, "xx1");
    XLSX.writeFile(wb, "sheet.xlsx");
    2.使用json_to_sheet():

    var data = JSON.parse(result.data);
    var ws = XLSX.utils.json_to_sheet(data);
    var wb = new XLSX.utils.book_new();
    const wopts = { bookType: 'xlsx', bookSST: false, type: 'binary' };

    downloadExl(data);
    function s2ab(s) {
    var buf = new ArrayBuffer(s.length);
    var view = new Uint8Array(buf);
    for (var i = 0; i != s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;
    return buf;
    }
    function saveAs(obj, fileName) {//自定义下载文件方式
    var tmpa = document.createElement("a");
    tmpa.download = fileName || "下载";
    tmpa.href = URL.createObjectURL(obj); //绑定a标签
    tmpa.click(); //模拟点击实现下载
    setTimeout(function () { //延时释放
    URL.revokeObjectURL(obj); //用URL.revokeObjectURL()来释放这个object URL
    }, 100);
    }
    function downloadExl(data) {
    const wb = { SheetNames: ['Sheet1'], Sheets: {}, Props: {} };
    wb.Sheets['Sheet1'] = XLSX.utils.json_to_sheet(data);//通过json_to_sheet转成单页(Sheet)数据
    saveAs(new Blob([s2ab(XLSX.write(wb, wopts))], { type: "application/octet-stream" }), "这里是下载的文件名" + '.' + (wopts.bookType == "biff2" ? "xls" : wopts.bookType));

    ————————————————
    版权声明:本文为CSDN博主「欧巴酱」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/qq_36894527/article/details/97788979

  • 相关阅读:
    CF938E Max History
    经典论文系列 | 目标检测--CornerNet & 又名 anchor boxes的缺陷
    在 Intenseye,为什么我们选择 Linkerd2 作为 Service Mesh 工具(Part.2)
    在 Intenseye,为什么我们选择 Linkerd2 作为 Service Mesh 工具(Part.1)
    Java概述
    算法 --- 二分法 冒泡排序 递归 快速排序
    二维数组
    数组
    SNMP "Simple Network Management Protocol" "简单网络管理协议"。
    常用api --- BigDecimal 包装类 Integer Arrays
  • 原文地址:https://www.cnblogs.com/dare/p/15698773.html
Copyright © 2020-2023  润新知