使用javascript / jQuery的HTML表格到Excel(xls)

时间:2015-06-11 23:58:13

标签: javascript jquery html excel html-table

我试图通过javascript / jquery导出将html表导出到Excel文档。到目前为止,我找到了2个解决方案,但都不符合我的要求:

HTML Table Export

  • 不导出内联样式(样式是必须要求)

Table2Excel

  • 不适用于所有IE版本(需要所有浏览器兼容性)

我正在寻找尽可能小的解决方案(这两种解决方案都非常“整洁”但是根据我上面的评论,它们都有一个不符合我要求的垮台。

有谁知道更好的解决方案?我对此出口的要求是:

  • 需要适用于所有浏览器
  • 需要导出内联样式
  • 如果可能能够命名文件会很高兴

非常感谢这里的任何帮助,拉出我的头发,因为我不能成为第一个需要此功能的人......

谢谢!

1 个答案:

答案 0 :(得分:1)

我认为PHP / Flash是不行的。 (如果没有,请结帐PHPExcelDataTables'导出功能。)

此外,如果没有某种类型的服务器端编程,则几乎不可能命名文件。我很确定这对大多数浏览器来说都是一个安全问题。

在我们开始使用代码之前,有一些限制:

  1. 您可能需要查找MS Office XML formats for XLS并自定义
  2. 一旦文件下载(它将是.xls),你可能会收到一个错误,例如“这个文件说它是XLS格式但可能不是,你想打开吗?”
  3. 您可能需要“另存为”一些有效的Excel格式,以强制它从Excel文档正文中的HTML转换。
  4. 我在Chrome / Firefox / Internet Explorer中使用过相当广泛但你应该自己测试一下。
  5. 目前设置为冻结行/列。更改tableToExcel()函数顶部的XML和/或冻结变量。
  6. 客户端资源昂贵。可能最好使用某种服务器端脚本。
  7. 根据javascript变量的大小,(我猜)表的大小是有限制的。我在50x300这样的表格中使用它,但我不建议在更大的桌子上使用它。
  8. 它接受一个HTML表格文本字符串(包括<table>)。您可以使用内联样式格式化HTML(不幸的是,不能使用CSS样式表)。

    tableToExcel($('table').html(),'Worksheet Name');

    这是功能。享受!

    function b64toBlob(b64Data, contentType, sliceSize) {
        contentType = contentType || '';
        sliceSize = sliceSize || 512;
    
        var byteCharacters = atob(b64Data);
        var byteArrays = [];
    
        for (var offset = 0; offset < byteCharacters.length; offset += sliceSize) {
            var slice = byteCharacters.slice(offset, offset + sliceSize);
    
            var byteNumbers = new Array(slice.length);
            for (var i = 0; i < slice.length; i++) {
                byteNumbers[i] = slice.charCodeAt(i);
            }
    
            var byteArray = new Uint8Array(byteNumbers);
    
            byteArrays.push(byteArray);
        }
    
        var blob = new Blob(byteArrays, {type: contentType});
        return blob;
    }
    
    function tableToExcel(table,name) {
    	var freezeTopRowNumber = '4';
    	var freezeColNumber = '6';
    	var 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">';
    	template += '<head><!--[if gte mso 9]>';
    	template += '<xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name>';
    	template += '<x:WorksheetOptions><x:Selected/><x:FreezePanes/><x:FrozenNoSplit/><x:SplitHorizontal>'+freezeTopRowNumber+'</x:SplitHorizontal><x:TopRowBottomPane>'+freezeTopRowNumber+'</x:TopRowBottomPane>';
    	template += '<x:SplitVertical>'+freezeColNumber+'</x:SplitVertical><x:LeftColumnRightPane>'+freezeColNumber+'</x:LeftColumnRightPane>';
    	template += '<x:ActivePane>2</x:ActivePane><x:Panes><x:Pane><x:Number>3</x:Number></x:Pane><x:Pane><x:Number>2</x:Number></x:Pane></x:Panes>';
    	template += '<x:ProtectContents>False</x:ProtectContents><x:ProtectObjects>False</x:ProtectObjects><x:ProtectScenarios>False</x:ProtectScenarios>';
    	template += '<x:DisplayGridlines/></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--></head>';
    	template += '<body>{table}</body></html>';
    	var base64 = function(s) { return window.btoa(unescape(encodeURIComponent(s))) };
    	var format = function(s, c) { return s.replace(/{(\w+)}/g, function(m, p) { return c[p]; }) };
    	var ctx = {worksheet: name || 'Worksheet', table: table};
    	var b = base64(format(template,ctx));
    
    	var blob = b64toBlob(b,'application/vnd.ms-excel');
    	var blobURL = URL.createObjectURL(blob);
    	window.location.href = blobURL;
    
    
    }