js導出excel


總的來說,兩種方法:服務器端生成和瀏覽器端生成。

 

服務器端生成就是:根據用戶請求,獲取相應的數據,使用poi/jxl, jacob/jawin+excel,或是用數據拼html的table或是cvs純文本的數據格式等。然后按.xls或是.cvs格式的文件的形式返回給用戶,指定Content-Type:application/vnd.ms-excel ,瀏覽器就會提示要下載的文件是excel文件。

 

poi/jxl, jacob/jawin生成的是excel的biff格式。html/csv的是文本格式,不另存為excel文件,很多excel功能是用不了的。jacob/jawin需要服務器端是windows系統,且安裝了excel2000以上版本。poi/jxl和html/csv方式的話,服務器端可以跨平台。

 

瀏覽器端生成excel文件還沒有特別完善的方案,這是因為js無法處理二進制。大概有以下幾個方案,各有利弊。

 

1. activex方式:使用js/vbs調用excel對象,http://setting.iteye.com/blog/219302,有個extjs的gridpanel導出為excel的例子。 (ie+excel)

 

2. ie命令方式:將html或是csv輸出到open的window,然后使用execCommand的saveas命令,存為csv或xls。 (ie6 only)

 

3. 服務器端中轉方式:將html的table或是拼接的csv傳到服務器端,服務器端再按照Content-Type:application/vnd.ms-excel返回,瀏覽器就會按excel方式處理。與服務器端拼接相比,少了一次取數操作。 (all)

 

4. data協議方式:對於支持data協議的瀏覽器,可以將html或是csv先用js base64處理,然后前綴data:application/vnd.ms-excel;base64,,即可使瀏覽器將其中的數據當做excel來處理,瀏覽器將提示下載或打開excel文件,可惜的是ie不支持。extjs的官網有一個grid的plugin,實現導出xhtml格式的偽excel文件,就是這么做的。 (except IE)

 

瀏覽器端只有第一種方案導出的是真正的biff格式的excel文件,其他方式都是文本格式。activex方式只能在windows平台的ie瀏覽器使用,而且需要降低ie的安全性,所以應用比較有限。復雜的excel文件,還是在服務器端用poi/jxl生成excel比較好。如果瀏覽器固定位ie6,瀏覽器端方式2是最好的方案。如果要降低服務器端cpu的計算壓力,客戶端方案3可行,而且跨平台(比poi/jxl方式少了取數和生成二進制文件)。如果是非ie瀏覽器,方案4也不失為一種好方法。

 

ps: 還有一個方案,就是讓安裝了ie和excel的用戶在網頁上右鍵,點擊“導出到 Microsoft Excel”,然后可以選擇要導出的table區域,點“導入”按鈕,完成導入。

 

方法一(推薦):

 基於微軟OpenXML協議,支持excel2007版本以上.

基於瀏覽器 data 協議 ,

歡迎點評,共同進步 !

注意:經測試此方法不支持ie瀏覽器

 

 

<html>
<head>
<meta http-equiv="content-Type" content="text/html;charset=utf-8"/>
<script type="text/javascript">
    function base64 (content) {
       return window.btoa(unescape(encodeURIComponent(content)));         
    }
    function exportOffice(dom,tableID,fName){
            var type = 'excel';
            var table = document.getElementById(tableID);
            var excelContent = table.innerHTML;
            var excelFile = "<html xmlns:o='urn:schemas-microsoft-com:office:office' xmlns:x='urn:schemas-microsoft-com:office:"+type+"' xmlns='http://www.w3.org/TR/REC-html40'>";
            excelFile += "<head>";
            excelFile += "<meta http-equiv=Content-Type; content=text/html;charset=UTF-8>";
            excelFile += "<!--[if gte mso 9]>";
            excelFile += "<xml>";
            excelFile += "<x:ExcelWorkbook>";
            excelFile += "<x:ExcelWorksheets>";
            excelFile += "<x:ExcelWorksheet>";
            excelFile += "<x:Name>";
            excelFile += "{worksheet}";
            excelFile += "</x:Name>";
            excelFile += "<x:WorksheetOptions>";
            excelFile += "<x:DisplayGridlines/>";
            excelFile += "</x:WorksheetOptions>";
            excelFile += "</x:ExcelWorksheet>";
            excelFile += "</x:ExcelWorksheets>";
            excelFile += "</x:ExcelWorkbook>";
            excelFile += "</xml>";
            excelFile += "<![endif]-->";
            excelFile += "</head>";
            excelFile += "<body><table>";
            excelFile += excelContent;
            excelFile += "</table></body>";
            excelFile += "</html>";
            var base64data = "base64," + base64(excelFile);
            switch(type){
                case 'excel':
                    dom.href ='data:application/vnd.ms-'+type+';'+base64data;;//必須是a標簽,否則無法下載改名
                    dom.download = fName;
                break;
            }
    }
</script>

</head>
<body>
<table id="targetTable">
  <tr align="center">
    <th>名次</th>
    <th>姓名</th>
    <th>成績</th>
  </tr>
  <tr align="center">
    <td>1</td>
    <td>小明</td>
    <td>100</td>
  </tr>
  <tr align="center">
    <td>2</td>
    <td>小紅</td>
    <td>95.5</td>
  </tr>
</table>
</br>
<a onClick="exportOffice(this,'targetTable','excel下載')" href="javascript:void(-1)">
<input id="Button1" type="button" value="導出" /> </a>
</body>
</html>

 

 原文鏈接 http://www.jianshu.com/p/a3642877d590  

方法二

 

var tableToExcel = (function() {
var uri = 'data:application/vnd.ms-excel;base64,',
template = '<html><head><meta charset="UTF-8"></head><body><table>{table}</table></body></html>',
base64 = function(s) { return window.btoa(unescape(encodeURIComponent(s))) },
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}
window.location.href = uri + base64(format(template, ctx))
}
})()


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM