在Vue中使用xlsx組件實現(xiàn)Excel導出功能的步驟詳解
1、項目設置
首先,在控制臺執(zhí)行以下命令安裝xlsx組件;
npm install xlsx --save 或 yarn add xlsx --save
然后,在vue項目中引入xls組件;
2、準備數據
要導出到Excel,您需要有數據。您可以使用本地數據或從API獲取數據。在本示例中,我們將使用本地數據:
exportData: [
{ name: "John", age: 30, city: "New York" },
{ name: "Alice", age: 25, city: "Los Angeles" },
{ name: "Bob", age: 35, city: "Chicago" }
]
3、實現(xiàn)導出功能
創(chuàng)建導出到Excel的方法。這個方法將觸發(fā)Excel文件的生成和下載:
exportToExcel() {
const worksheet = XLSX.utils.json_to_sheet(this.exportData);
const workbook = XLSX.utils.book_new();
XLSX.utils.book_append_sheet(workbook, worksheet, "Sheet1");
XLSX.writeFile(workbook, "exported-data.xlsx");
}這個方法使用xlsx組件將數據轉換為Excel工作表,然后創(chuàng)建一個工作簿并將工作表添加到工作簿中。最后,它使用XLSX.writeFile方法將工作簿保存為名為"exported-data.xlsx"的Excel文件。
4、設置列寬自適應
根據導出數據的長度,通過遍歷計算每列的最大長度,然后通過worksheet['!cols']方法設置每列寬度;
// 設置列寬
exportData.forEach((row, rowIndex) => {
row.forEach((cell, cellIndex) => {
const list = arrData.map(item => {
const val = item[cellIndex] as string;
if(isEmptyString(val)){
return 1;
} else if(val.toString().charCodeAt(0) > 255){ // 判斷是否有中文
return val.toString().length * 2
} else{
return val.toString().length;
}
});
const maxLength = Math.max(...list);
const width = maxLength * 1.1; // 根據實際內容長度自動調整列寬
if(!worksheet["!cols"]) worksheet["!cols"] = [];
if(!worksheet["!cols"][cellIndex]) worksheet["!cols"][cellIndex] = {wch: 8};
worksheet['!cols'][cellIndex].wch = width; // 使用worksheet的 '!cols' 來設置列寬
});
}); 5、設置合并單元格
通過worksheet["!merges"]方法可以設置合并單元格;
// 合并單元格
merges.forEach((item) => {
if(!worksheet["!merges"]){
worksheet["!merges"] = [];
};
worksheet["!merges"].push(item);
// worksheet["!merges"].push({
// s: { r: 2, c: 1 }, // s ("start"): c = 1 r = 2 -> "B3"
// e: { r: 3, c: 4 } // e ("end"): c = 4 r = 3 -> "E4"
// });
});6、設置導出Excel表格的樣式
xlsx組件庫是不支持設置Excel表格樣式的,但是可以通過引入xlsx-style-vite組件庫來實現(xiàn)樣式的設置;然后通過file-saver導出文件;
6.1 安裝并引入xlsx-style-vite和file-saver組件
yarn add xlsx-style-vite --save yarn add file-saver --save
import XLSXStyle from 'xlsx-style-vite'; import XLSX_SAVE from 'file-saver';
其中 xlsx-style-vite組件是xlsx-style組件的vite版本,用于解決在vite下引入xlsx-style異常的問題;
6.2 設置單元格居中
遍歷所有單元格,然后通過worksheet[column].s方法設置每個單元格的樣式;
exportData.forEach((row, rowIndex) => {
row.forEach((cell, cellIndex) => {
// 設置所有單元格居中
let column = utils.encode_cell({c: cellIndex, r: rowIndex});
worksheet[column].s = {
alignment: {
horizontal: 'center',
vertical: 'center',
wrapText: false, // 自動換行
},
}
});
}); 6.3 設置單元格背景色和字體
exportData.forEach((row, rowIndex) => {
row.forEach((cell, cellIndex) => {
// 設置所有單元格居中
let column = utils.encode_cell({c: cellIndex, r: rowIndex});
if(worksheet[column]){
// 設置背景色、加粗展示
worksheet[column].s = {
font: {
name: "微軟雅黑",
sz: 16,
color: { rgb: "000000" },
bold: true,
italic: false,
underline: false,
},
fill: {
fgColor: { rgb: "C5D9F1" },
},
alignment: {
horizontal: 'center',
vertical: 'center',
wrapText: false, // 自動換行
},
}
}
}
});
}); 6.4 設置單元格邊框
//單元格外側框線
const borderAll = {
top: {
style: "thin",
},
bottom: {
style: "thin",
},
left: {
style: "thin",
},
right: {
style: "thin",
},
};
// 設置單元格邊框
arrData.forEach((row, rowIndex) => {
row.forEach((cell, cellIndex) => {
let column = utils.encode_cell({c: cellIndex, r: rowIndex});
if(worksheet[column]){
worksheet[column].s = {
border: borderAll,
}
}
}
});
}); 6.5 導出文件
必須通過file-saver組件導出Excel文件,不能通過xlsx組件的writeFile方法導出文件,否則樣式無法生效;
const wbout = XLSXStyle.write(workbook, {
type: 'binary',
bookType: 'xlsx',
});
XLSX_SAVE.saveAs(
new Blob([s2ab(wbout)], {
type: 'application/octet-stream',
}),
'exported-data.xlsx',
);
// 數據轉換
function s2ab(s) {
var buf = new ArrayBuffer(s.length);
var view = new Uint8Array(buf);
for (var i=0; i!=s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;
return buf;
}7、完整代碼示例
import * as xlsx from 'xlsx';
import type { WorkBook } from 'xlsx';
import type { JsonToSheet, AoAToSheet } from './typing';
import XLSXStyle from 'xlsx-style-vite';
import XLSX_SAVE from 'file-saver';
import { isEmptyString } from '@/utils/table';
const { utils, writeFile } = xlsx;
const DEF_FILE_NAME = 'excel-list.xlsx';
export function aoaToSheetXlsx<T = any>({
data,
header,
filename = DEF_FILE_NAME,
write2excelOpts = { bookType: 'xlsx' },
merges = [],
}: AoAToSheet<T>) {
const arrData = [...data];
if (header) {
arrData.unshift(header);
}
const worksheet = utils.aoa_to_sheet(arrData);
/* add worksheet to workbook */
const workbook: WorkBook = {
SheetNames: [filename],
Sheets: {
[filename]: worksheet,
},
};
//單元格外側框線
const borderAll = {
top: {
style: "thin",
},
bottom: {
style: "thin",
},
left: {
style: "thin",
},
right: {
style: "thin",
},
};
// 設置列寬
arrData.forEach((row, rowIndex) => {
row.forEach((cell, cellIndex) => {
const list = arrData.map(item => {
const val = item[cellIndex] as string;
if(isEmptyString(val)){
return 1;
} else if(val.toString().charCodeAt(0) > 255){ // 判斷是否有中文
return val.toString().length * 2
} else{
return val.toString().length;
}
});
const maxLength = Math.max(...list);
const width = maxLength * 1.1; // 根據實際內容長度自動調整列寬
if(!worksheet["!cols"]) worksheet["!cols"] = [];
if(!worksheet["!cols"][cellIndex]) worksheet["!cols"][cellIndex] = {wch: 8};
worksheet['!cols'][cellIndex].wch = width; // 使用worksheet的 '!cols' 來設置列寬
// 設置所有單元格居中
let column = utils.encode_cell({c: cellIndex, r: rowIndex});
if(worksheet[column]){
if(rowIndex === 0) { // 標題行設置背景色、加粗展示
worksheet[column].s = {
border: borderAll,
font: {
// name: "微軟雅黑",
// sz: 16,
color: { rgb: "000000" },
bold: true,
italic: false,
underline: false,
},
fill: {
fgColor: { rgb: "C5D9F1" },
},
alignment: {
horizontal: 'center',
vertical: 'center',
wrapText: false, // 自動換行
},
}
} else {
worksheet[column].s = {
alignment: {
horizontal: 'center',
vertical: 'center',
wrapText: false, // 自動換行
},
}
}
}
});
});
// 合并單元格
merges.forEach((item) => {
if(!worksheet["!merges"]){
worksheet["!merges"] = [];
};
worksheet["!merges"].push(item);
// worksheet["!merges"].push({
// s: { r: 2, c: 1 }, // s ("start"): c = 1 r = 2 -> "B3"
// e: { r: 3, c: 4 } // e ("end"): c = 4 r = 3 -> "E4"
// });
});
const wbout = XLSXStyle.write(workbook, {
type: 'binary',
bookType: 'xlsx',
});
XLSX_SAVE.saveAs(
new Blob([s2ab(wbout)], {
type: 'application/octet-stream',
}),
`${filename}.${write2excelOpts.bookType}`,
);
/* output format determined by filename */
// writeFile(workbook, filename, write2excelOpts);
/* at this point, out.xlsb will have been downloaded */
}
// 數據轉換
function s2ab(s) {
var buf = new ArrayBuffer(s.length);
var view = new Uint8Array(buf);
for (var i=0; i!=s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;
return buf;
}以上就是在Vue中使用xlsx組件實現(xiàn)Excel導出功能的步驟詳解的詳細內容,更多關于Vue xlsx組件實現(xiàn)Excel導出的資料請關注腳本之家其它相關文章!
- Vue3如何利用xlsx、xlsx-js-style導出Excel表格使用(適合新手)
- vue使用luckyexcel實現(xiàn)在線表格及導出導入方式
- 前端實現(xiàn)Excel文件導出功能的完整代碼解析(vue實現(xiàn)excel文件導出)
- vue2項目使用exceljs多表頭導出功能詳解
- Vue用Export2Excel導出excel,多級表頭數據方式
- vue使用Luckysheet插件實現(xiàn)excel導入導出
- vue使用xlsx庫和xlsx-style庫導入導出excel、設置單元格背景色、文字居中、合并單元格、設置列寬
- 在Vue中實現(xiàn)Excel導出功能(數據導出)
相關文章
element-ui中el-upload多文件一次性上傳的實現(xiàn)
這篇文章主要介紹了element-ui中el-upload多文件一次性上傳的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-12-12
基于Vue3和Element Plus實現(xiàn)自動導入功能
在 Vue 3 項目中,結合 Element Plus 實現(xiàn)自動導入可以顯著減少代碼量,提升開發(fā)效率,Element Plus 提供了官方的自動導入插件 unplugin-vue-components 和 unplugin-auto-import,以下是如何配置和使用的詳細步驟,需要的朋友可以參考下2025-03-03
利用Vue3+Element?Plus封裝公共表格組件(帶源碼)
最近公司項目中頻繁會使用到table表格,而且前端技術這一塊也用到了vue3來開發(fā),所以基于element plus table做了一個二次封裝的組件,這篇文章主要給大家介紹了關于利用Vue3+Element?Plus封裝公共表格組件的相關資料,需要的朋友可以參考下2023-11-11

