Vue導出el-table表格為Excel文件的兩種方式
前言
在開發(fā)過程中,我們經(jīng)常需要將表格數(shù)據(jù)導出為 Excel 文件。大多數(shù)情況下,由后端處理即可,但是當數(shù)據(jù)量不大、需要快速響應用戶操作、或者數(shù)據(jù)已經(jīng)在前端進行處理和展示時,前端該如何實現(xiàn)呢。本文將介紹兩種方法:一種是使用 xlsx.js
進行簡單導出,另一種是使用 xlsx-style-medalsoft
進行樣式化導出,包括多 sheet 支持。
方式一:簡單導出
首先,我們使用 xlsx.js
庫實現(xiàn)基本的表格導出功能。這種方法不包含樣式,適用于快速導出數(shù)據(jù)。
import * as XLSX from 'xlsx'; // 創(chuàng)建一個新的工作簿 const book = XLSX.utils.book_new(); // 將 HTML 表格轉換為工作表 const sheet = XLSX.utils.table_to_sheet(this.$refs.exportTableRef.$el); // 將工作表添加到工作簿 XLSX.utils.book_append_sheet(book, sheet, "Sheet1"); // 導出工作簿為 Excel 文件 XLSX.writeFile(book, "xxx統(tǒng)計.xlsx");
方式二:多 sheet 導出,帶樣式
對于更復雜的需求,如導出多個工作表或添加樣式,我們可以使用 xlsx-style-medalsoft
庫。
安裝依賴
首先,安裝必要的依賴:
這里注意版本號,有些版本可能會出現(xiàn)問題,我本地目前版本如下
"file-saver": "^2.0.5", "xlsx": "^0.16.9", "xlsx-style-medalsoft": "^0.8.13"
封裝導出功能
接下來,我們封裝一個函數(shù),用于導出帶樣式的 Excel 文件:
import FileSaver from 'file-saver'; import * as XLSX from 'xlsx'; import XLSXStyle from 'xlsx-style-medalsoft'; const OMS = {}; // 導出 Excel 文件,支持多 sheet 和樣式 OMS.downLoadXlsx = ({ sheets = [], name = '文件' }) => { const workbook = XLSX.utils.book_new(); sheets.forEach(sheetData => { const { dom, sheetName, columnWidth = [], raw } = sheetData; const table = dom; // 移除固定列,避免重復內容 ['el-table__fixed', 'el-table__fixed-right'].forEach(className => { const fixedTable = table.querySelector(`.${className}`); if (fixedTable) table.removeChild(fixedTable); }); // 轉換表格為工作表 const sheet = XLSX.utils.table_to_sheet(table, { raw }); // 刪除空行 Object.keys(sheet).forEach(key => { if (!key.startsWith('!') && sheet[key].v === '') delete sheet[key]; }); // 設置列寬度 if (columnWidth.length > 0) { columnWidth.forEach((width, index) => { sheet['!cols'][index] = { wch: width }; }); } else { // 默認列寬 for (let i = 0; i < 30; i++) { sheet['!cols'][i] = { wch: 12.5 }; } } // 應用樣式 Object.keys(sheet).forEach(key => { if (!key.startsWith('!')) { sheet[key].s = { font: { sz: 11, bold: false, name: '宋體', color: { rgb: '000000' } }, alignment: { horizontal: 'center', vertical: 'center', wrapText: false }, border: {} }; } }); // 合并單元格 const range = sheet['!merges']; if (range) { range.forEach(item => { const startCol = item.s.c, endCol = item.e.c; const startRow = item.s.r, endRow = item.e.r; const firstCell = sheet[XLSX.utils.encode_cell({ r: startRow, c: startCol })]; for (let row = startRow; row <= endRow; row++) { for (let col = startCol; col <= endCol; col++) { sheet[XLSX.utils.encode_cell({ r: row, c: col })] = firstCell; } } }); } // 添加工作表到工作簿 XLSX.utils.book_append_sheet(workbook, sheet, sheetName); }); // 導出工作簿 const excelData = XLSXStyle.write(workbook, { bookType: 'xlsx', type: 'buffer' }); FileSaver.saveAs(new Blob([excelData], { type: 'application/octet-stream' }), `${name}.xlsx`); }; export default OMS;
使用方法
最后,我們在需要使用的地方引入:
import OMS from "@/utils/exportToExcel"; OMS.downLoadXlsx({ sheets: [ { dom: this.$refs.rowTableRef.$el, sheetName: this.rowData[0].hospName, columnWidth: [20, 15, 15, 15, 15, 15, 15, 15] // 可選,設置列寬度 }, { dom: this.$refs.table.$el, sheetName: "明細", raw: true, columnWidth: [10, 15, 12, 15, 15, 15, 15, 15] // 可選,設置列寬度 } // 可添加更多工作表 ], name: "報告" });
通過這種方式,我們就實現(xiàn)了前端導出帶樣式的 Excel 文件,滿足多 sheet,帶樣式的業(yè)務需求。
但是需要注意的是如果數(shù)據(jù)量不大、需要快速響應用戶操作、或者數(shù)據(jù)已經(jīng)在前端進行處理和展示,前端來做導出是可以的。而如果數(shù)據(jù)量很大、需要復雜的數(shù)據(jù)處理、或者需要保證數(shù)據(jù)的安全性和一致性,后端導出可能更合適。
以上就是Vue導出el-table表格為Excel文件的兩種方式的詳細內容,更多關于Vue導出el-table為Excel的資料請關注腳本之家其它相關文章!
相關文章
Vue項目中安裝依賴npm?install一直報錯的解決過程
這篇文章主要給大家介紹了關于Vue項目中安裝依賴npm?install一直報錯的解決過程,要解決NPM安裝依賴報錯,首先要分析出錯誤的原因,文中將解決的過程介紹的非常詳細,需要的朋友可以參考下2023-05-05vue+springboot+element+vue-resource實現(xiàn)文件上傳教程
這篇文章主要介紹了vue+springboot+element+vue-resource實現(xiàn)文件上傳教程,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10vue.js中methods watch和computed的區(qū)別示例詳解
methods,watch和computed都是以函數(shù)為基礎的,但各自卻都不同,這篇文章主要給大家介紹了關于vue.js中methods watch和computed區(qū)別的相關資料,需要的朋友可以參考下2021-08-08vue axios sessionID每次請求都不同的原因以及修改方式
這篇文章主要介紹了vue axios sessionID每次請求都不同的原因以及修改方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12Vue中使用v-model雙向數(shù)據(jù)綁定select、checked等多種表單元素的方法
?v-model?指令可以用在表單?input、textarea?及?select?元素上創(chuàng)建雙向數(shù)據(jù)綁定,它會根據(jù)控件類型自動選取正確的方法來更新元素,本文給大家介紹Vue中如何使用v-model雙向數(shù)據(jù)綁定select、checked等多種表單元素,感興趣的朋友一起看看吧2023-10-10