html導(dǎo)出Excel的實(shí)現(xiàn)方法

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

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

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

瀏覽器端生成excel文件還沒有特別完善的方案,這是因?yàn)?a target="_blank" rel="nofollow">js無法處理二進(jìn)制。大概有以下幾個(gè)方案,各有利弊。

1. activex方式:使用js/vbs調(diào)用excel對(duì)象,使用extjs的gridpanel可以導(dǎo)出為excel。

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

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

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

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

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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,533評(píng)論 19 139
  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標(biāo)簽?zāi)J(rèn)的外補(bǔ)...
    _Yfling閱讀 14,108評(píng)論 1 92
  • 一、概念(載錄于:http://www.cnblogs.com/EricaMIN1987_IT/p/3837436...
    yuantao123434閱讀 8,738評(píng)論 6 152
  • Http協(xié)議詳解 標(biāo)簽(空格分隔): Linux 聲明:本片文章非原創(chuàng),內(nèi)容來源于博客園作者M(jìn)IN飛翔的HTTP協(xié)...
    Sivin閱讀 5,344評(píng)論 3 82
  • 至于我們的相遇,我有很多種比喻 比如大火席卷麥田 ——我把所有收成抵擋給一場(chǎng)虛妄 此刻,一對(duì)瓷鶴審視著我:著從我身...
    執(zhí)念太深就易傷閱讀 432評(píng)論 0 0

友情鏈接更多精彩內(nèi)容