美文网首页
导出Excel图表

导出Excel图表

作者: 初见_JS | 来源:发表于2020-03-26 11:20 被阅读0次
    • 下载同时导入xlsx
    npm i xlsx
    import XLSX from 'xlsx'
    
    • 导出方法封装
    import XLSX from 'xlsx'
    export default {
        sheet2blob(sheet, sheetName) {
            sheetName = sheetName || 'sheet1';
            var workbook = {
                SheetNames: [sheetName],
                Sheets: {}
            };
            workbook.Sheets[sheetName] = sheet;
            // 生成excel的配置项
            var wopts = {
                bookType: 'xlsx', // 要生成的文件类型
                bookSST: false, // 是否生成Shared String Table,官方解释是,如果开启生成速度会下降,但在低版本IOS设备上有更好的兼容性
                type: 'binary'
            };
            var wbout = XLSX.write(workbook, wopts);
            var blob = new Blob([s2ab(wbout)], { type: "application/octet-stream" });
            // 字符串转ArrayBuffer
            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;
            }
            return blob;
        },
        openDownloadDialog(url, saveName) {
            if (typeof url == 'object' && url instanceof Blob) {
                url = URL.createObjectURL(url); // 创建blob地址
            }
            var aLink = document.createElement('a');
            aLink.href = url;
            aLink.download = saveName || ''; // HTML5新增的属性,指定保存文件名,可以不要后缀,注意,file:///模式下不会生效
            var event;
            if (window.MouseEvent) event = new MouseEvent('click');
            else {
                event = document.createEvent('MouseEvents');
                event.initMouseEvent('click', true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
            }
            aLink.dispatchEvent(event);
        },
    }
    
    • 最终实现
        import Export from "./Export";
        import XLSX from "xlsx";
        //导出excel
        exportExcel() {
          let title = [];
          this.tableField = {
            time: "时间",
            inFloatTotal: "入库流量(m³/s)",
            outFloatTotal: "出库流量(m³/s)",
            currentReserLevel: "库水位(m)"
          }
          for (const key in this.tableField) {
            title.push(this.tableField[key]);
          }
          var aoa = [];
          aoa.push(title);
          this.regulResultsData.forEach(item => {
            let temp = [];
            for (const key in this.tableField) {
              temp.push(item[key]);
            }
            aoa.push(temp);
          });
          console.dir(aoa);
          var sheet = XLSX.utils.aoa_to_sheet(aoa);
          Export.openDownloadDialog(
            Export.sheet2blob(sheet),
            "报表导出.xlsx"
          );
        }
    

    相关文章

      网友评论

          本文标题:导出Excel图表

          本文链接:https://www.haomeiwen.com/subject/yiirshtx.html