JavaScript生成.xls文件的代碼
貼代碼,一切盡在注釋中
<html> <head> <meta charset="utf-8"> </head> <body> <input type="button" value="下載設(shè)備模板" onclick="foo;" /> <script type="text/javascript" language="javascript"> var downloadTemplate = function { /** * 根據(jù)所給數(shù)據(jù)創(chuàng)建并返回單行 tr節(jié)點(diǎn) * data (必選), tag (可選, 標(biāo)識創(chuàng)建的節(jié)點(diǎn)類型) **/ var getTr=function(data,tag) { var tr=document.createElement("tr"); for(var i=0;i<data.length;i++) { var item=document.createElement(tag||"td"); item.innerHTML=data[i]; tr.appendChild(item); } return tr; } ; /** * 根據(jù)所給數(shù)據(jù)創(chuàng)建并返回 table節(jié)點(diǎn) * data (可選,無則返回空的table節(jié)點(diǎn)), head(可選, 標(biāo)識是否存在表頭) **/ var getTable=function(data,head) { var table=document.createElement("table"); var head=head||false; //存在表頭設(shè)標(biāo)識為th,否則為td var tag=head?"th":"td"; //判斷是一維||二維,執(zhí)行不同邏輯 if(data[0] instanceof Array) { for(var i=0;i<data.length;i++) { //第一行數(shù)據(jù)根據(jù)tag創(chuàng)建節(jié)點(diǎn)類型 (i==0)?table.appendChild(getTr(data[i],tag)):table.appendChild(getTr(data[i])); } } else if(data instanceof Array) table.appendChild(getTr(data,tag)); return table; } ; /** * table (必選, table節(jié)點(diǎn)) * uri 為生成excel的頭部標(biāo)簽 * xmlns xml命名空間 * 返回xls資源 **/ var getXls=function(table) { var uri = 'data:application/vnd.ms-excel;base64,'; 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">'+ '<head>'+ '<!--[if gte mso 9]>'+ '<xml>'+ '<x:ExcelWorkbook>'+ '<x:ExcelWorksheets>'+ '<x:ExcelWorksheet>'+ '<x:WorksheetOptions>'+ '<x:DisplayGridlines/>'+ '</x:WorksheetOptions>'+ '</x:ExcelWorksheet>'+ '</x:ExcelWorksheets>'+ '</x:ExcelWorkbook>'+ '</xml>'+ '<![endif]-->'+ '</head>'+ '<body>'+ '<table>{table}</table>'+ '</body>'+ '</html>'; /** * 轉(zhuǎn)碼 base 64 * window.btoa能從ascii/二進(jìn)制流中創(chuàng)建一個base64編碼的字符串 * escape編碼 unescape 解碼字符串 * encodeURIComponent編碼 DecodeURIComponent 解碼字符串 **/ var base64 = function(s) { return window.btoa(unescape(encodeURIComponent(s))); }; //返回替換完具體數(shù)據(jù)的xls模板 var getXlsXml = function(template,data) { return template.replace(/{(\w+)}/g,data); }; //返回資源鏈接 return uri+base64(getXlsXml(template, table.innerHTML)); }; /** * IE瀏覽器 * 使用Microsoft ActiveXObject組件生成xls ( 只兼容IE瀏覽器,選擇允許加載組件 ) * table(必選, table節(jié)點(diǎn)) **/ var msDownload=function(data) { var xls = new ActiveXObject("Excel.Application"); xls.visible = true; var xlsBook = xls.Workbooks.Add; var xlsheet = xlsBook.Worksheets(1); for(var i=0;i<data.length;i++) if(data[0] instanceof Array) for(var j=0;j<data[0].length;j++) xlsheet.Cells(i+1,j+1).Value=data[i][j]; else xlsheet.Cells(1,i+1).Value=data[i]; //用完釋放 xls=null; }; //參數(shù): data(必選,一維||二維 數(shù)組), head(可選, 標(biāo)識是否存在表頭) var download=function(data , head) { if(window.navigator.userAgent.indexOf("MSIE") >= 0) msDownload(data); else //下載(RestFul:資源下載置于超鏈接,地址為資源定位地址) window.location.href =getXls(getTable(data,head)); }; return { getXls:getXls, msDownload:msDownload, download:download }; }; //測試數(shù)據(jù) var od=['aid','pwd','設(shè)備名稱','網(wǎng)關(guān)DK','區(qū)域']; var td=[ ['aid','pwd','設(shè)備名稱','網(wǎng)關(guān)DK','區(qū)域'], ['10086','root','松下R-399','208564165456542','2 #201'], ['10001','root','索尼SUV 09','456542895564165','2 #201'] ]; var foo=function { // new downloadTemplate.download(od,true); new downloadTemplate.download(td,true); } ; </script> </body> </html>
測試結(jié)果:
在IE瀏覽器上需要允許加載ActiveX控件,之后在彈出的對話框中點(diǎn)擊"是"
下載下來的表格如下:
chrome:
打開表格:
以上所述是小編給大家介紹的JavaScript生成.xls文件的代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
js實(shí)現(xiàn)創(chuàng)建刪除html元素小結(jié)
本文給大家簡單介紹了下使用javascript和jquery實(shí)現(xiàn)創(chuàng)建刪除html元素的方法,非常的實(shí)用,有需要的小伙伴可以參考下。2015-09-09一文詳解如何通過JavaScript動態(tài)修改元素的樣式
這篇文章主要介紹了如何通過JavaScript動態(tài)修改元素的樣式,三種方式分別是直接操作元素的style屬性、通過classList屬性添加或移除類名、以及使用CSSStyleDeclaration對象的setProperty方法,每種方法都有其適用場景,需要的朋友可以參考下2024-12-12設(shè)置cookie指定時間失效(實(shí)例代碼)
下面小編就為大家?guī)硪黄O(shè)置cookie指定時間失效(實(shí)例代碼)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05JavaScript 基礎(chǔ)表單驗(yàn)證示例(純Js實(shí)現(xiàn))
下面小編就為大家?guī)硪黄狫avaScript 基礎(chǔ)表單驗(yàn)證示例(純Js實(shí)現(xiàn))。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07javaScript如何跳出多重循環(huán)break、continue
這篇文章主要為大家詳細(xì)介紹了javaScript如何跳出多重循環(huán)break、continue,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09原生js封裝二級城市下拉列表的實(shí)現(xiàn)代碼
下面小編就為大家?guī)硪黄鷍s封裝二級城市下拉列表的實(shí)現(xiàn)代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06JS使用Date對象實(shí)時顯示當(dāng)前系統(tǒng)時間簡單示例
這篇文章主要介紹了JS使用Date對象實(shí)時顯示當(dāng)前系統(tǒng)時間,涉及javascript基于定時器動態(tài)操作Date對象相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-08-08JS實(shí)現(xiàn)動態(tài)表格的添加,修改,刪除功能(推薦)
這篇文章主要介紹了JS實(shí)現(xiàn)動態(tài)表格的添加,修改,刪除功能(推薦)的相關(guān)知識,非常不錯,具有參考借鑒價(jià)值,感興趣的朋友一起學(xué)習(xí)吧2016-06-06