使用JS导出表格数据至Excel的体验 -- 含源码分析

首先,感谢原作者的整理与创作 – JS 导出 Excel 代码部分贡献:
JS导出excel 兼容ie、chrome、firefox – 分析对象
HTML用JS导出Excel的五种方法

自述:
之前做的一个项目客户要求 Excel 导出数据的功能;
一般来说,我会选择 poi.jar 来完成 Excel 导出功能;
但是…我为了省事,而选择了 JS 来完成这项工作;
当时没多想,随便在网上找了些代码,Chrome 浏览器上一跑就完事;
果不其然,JS 导出 Excel 坑有很多,着实不推荐这么搞;
以下为源码分析:

/**
 * 源码主要分为3个部分:
 * 1.获取浏览器类型
 * 2.IE浏览器表格导出
 * 3.其他主流浏览器导出
 */

/* 1.获取浏览器类型 */
function  getExplorer() {
    var explorer = window.navigator.userAgent;
    //ie
    if (explorer.indexOf("MSIE") >= 0) {
        return 'ie';
    }
    //firefox
    else if (explorer.indexOf("Firefox") >= 0) {
        return 'Firefox';
    }
    //Chrome
    else if(explorer.indexOf("Chrome") >= 0){
        return 'Chrome';
    }
    //Opera
    else if(explorer.indexOf("Opera") >= 0){
        return 'Opera';
    }
    //Safari
    else if(explorer.indexOf("Safari") >= 0){
        return 'Safari';
    }
}

这段代码并不难懂
window.navigator.userAgent:得到当前 访问者代理头信息,格式一般如下:
Chrome 浏览器结果:Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/65.0.3325.181 Safari/537.36

那么,拿到了 访问者代理头信息,我们便可以粗略的判断一下其浏览器类型;

但是:这段代码并不能准确的获取浏览器类型;

我在 win10 操作系统上的 IE 11 浏览器运行以上代码,其不能发现我是 IE 浏览器…(原因在于,微软在 IE 11 上去掉了 MSIE 标识 )

只用 .index.Of(str) 这样的函数去判断,是不准确的;至于为什么,仔细看看 访问者代理头 信息即可知道,Chrome 浏览器的 访问者代理头信息 居然有 AppleWebKitSafari 等标识…这则是另外一个故事了:
浏览器野史 UserAgent列传(上)浏览器野史 UserAgent列传(下)

关于 JS 判断 浏览器类型 的代码推荐:
JS获取当前浏览器及版本信息

<!-- HTML代码,` table `为表格id -->
<input type="button" value="导出EXCEL" onclick="method1('table')" />

/* 2.IE浏览器表格导出 */
function method1(tableid) {
    // 如果是IE浏览器
    if(getExplorer()=='ie') {
        var curTbl = document.getElementById(tableid);
        var oXL = new ActiveXObject("Excel.Application");

        //创建AX对象excel
        var oWB = oXL.Workbooks.Add();
        //获取workbook对象
        var xlsheet = oWB.Worksheets(1);
        //激活当前sheet
        var sel = document.body.createTextRange();
        sel.moveToElementText(curTbl);
        //把表格中的内容移到TextRange中
        sel.select;
        //全选TextRange中内容
        sel.execCommand("Copy");
        //复制TextRange中内容
        xlsheet.Paste();
        //粘贴到活动的EXCEL中
        oXL.Visible = true;
        //设置excel可见属性

        try {
            var fname = oXL.Application.GetSaveAsFilename("Excel.xls", "Excel Spreadsheets (*.xls), *.xls");
        } catch (e) {
            print("Nested catch caught " + e);
        } finally {
            oWB.SaveAs(fname);

            oWB.Close(savechanges = false);
            //xls.visible = false;
            oXL.Quit();
            oXL = null;
            //结束excel进程,退出完成
            //window.setInterval("Cleanup();",1);
            idTmr = window.setInterval("Cleanup();", 1);
        }
    } else {
        tableToExcel('ta')
    }
}

之前已经说了,由于第一部分代码无法准确的判断 浏览器类型,以至于这段代码对于 IE 11 是失效的…
关于 IE 浏览器的 JS 导出 Excel 本人未做过多的了解,此段代码只能分析至此…

如果你有兴趣了解,建议从 ActiveXObject 对象开始了解;
ActiveXObject 此对象为 Microsoft 扩展,仅在 Internet Explorer 中受支持;

/* 3.其他主流浏览器导出 */
var tableToExcel = (function() {
    var uri = 'data:application/vnd.ms-excel;base64,',
    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>',
    base64 = function(s) {
        return window.btoa(unescape(encodeURIComponent(s)))
    },
    // 下面这段函数作用是:将template中的变量替换为页面内容ctx获取到的值
    format = function(s, c) {
            return s.replace(/{(\w+)}/g,
                function(m, p) {
                    return c[p];
                }
            )
    };
    return function(table, name) {
        if (!table.nodeType) {
            table = document.getElementById(table);
        }
        // 获取表单的名字和表单查询的内容
        var ctx = {worksheet: name || 'Worksheet', table: table.innerHTML};
        // format()函数:通过格式操作使任意类型的数据转换成一个字符串
        // base64():进行编码
        window.location.href = uri + base64(format(template, ctx));
    }
})();

最后一段代码,我也没太仔细研究(其实是看不懂 Σ( ° △ °|||)︴);
那么就这样吧,最后总结一下:

JS(前端) 导出 Excel 的优缺点:

优点: 方便;

缺点: 兼容性问题,分页数据如何全部导出问题,Excel 样式问题;

各位看官请酌情选择,我还是滚回去老老实实弄 poi 进行Excel导出吧;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章