總的來說,兩種方法:服務器端生成和瀏覽器端生成沟于。
服務器端生成就是:根據用戶請求渴丸,獲取相應的數據,使用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對象灾炭,使用extjs的gridpanel可以導出為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區(qū)域硫戈,點“導入”按鈕锰什,完成導入。