Vue使用xlsx和xlsx-style導(dǎo)出表格出現(xiàn)部分樣式缺失的問(wèn)題解決
這篇說(shuō)一下使用xlsx-style導(dǎo)出excel時(shí)樣式的設(shè)置。需要安裝xlsx、xlsx-style、file-saver插件(file-saver可以不裝,用a標(biāo)簽代替也可以),安裝時(shí)可能會(huì)碰到一些報(bào)錯(cuò)問(wèn)題,可以去看下我之前一篇博客:純前端導(dǎo)出Excel并修改樣式
由于上次寫(xiě)的修改樣式只關(guān)注了單元格的寬度,并沒(méi)有設(shè)置顏色以及沒(méi)關(guān)注到合并的單元格部分樣式?jīng)]設(shè)置上等問(wèn)題,所以這篇來(lái)說(shuō)下。
我們通過(guò)xlsx可以通過(guò)dom元素、或者數(shù)據(jù)來(lái)生產(chǎn)sheet頁(yè),然后我們修改樣式就操作對(duì)應(yīng)的sheet頁(yè)就可以了。
直接上代碼如下:
我這個(gè)是直接通過(guò)傳入dom生產(chǎn)的sheet頁(yè),也可以通過(guò)數(shù)據(jù)生成sheet頁(yè),xlsx都有對(duì)應(yīng)的方法,其實(shí)不影響我們修改樣式 。主要關(guān)注addRangeBorder(給合并行列賦值樣式)、setExcelStyle(設(shè)置導(dǎo)出Excel樣式)這兩個(gè)方法。
import * as XLSX from 'xlsx'
import FileSaver from 'file-saver'
import XLSXS from 'xlsx-style'
/**
* 根據(jù)DOM進(jìn)行導(dǎo)出
* @param {Element} dom
* @param {String} fileName
*/
export function exportExcelByDom(dom, fileName) {
const book = XLSX.utils.book_new()
const sheet = XLSX.utils.table_to_sheet(dom)
XLSX.utils.book_append_sheet(book, sheet, 'Sheet1')
addRangeBorder(sheet['!merges'], sheet) // 給合并行列賦值樣式
setExcelStyle(sheet) // 設(shè)置樣式
let wbout = XLSXS.write(book, {
bookType: 'xlsx',
bookSST: false,
type: 'binary'
})
try {
FileSaver.saveAs(new Blob([s2ab(wbout)], { type: "application/octet-stream" }), fileName);
} catch (e) {
console.error(e, wbout, '----->>>')
}
}
// 設(shè)置導(dǎo)出Excel樣式(統(tǒng)一樣式)
function setExcelStyle(data, wpx = 80) {
data["!cols"] = []
const excludes = ['!cols', '!fullref', '!merges', '!ref', '!rows']
for (let key in data) {
if (data.hasOwnProperty(key)) {
if (!excludes.includes(key)) {
data[key].s = {
alignment: {
horizontal: "center", //水平居中對(duì)齊
vertical: "center", // 垂直居中
wrapText: true,
},
border: {
top: {
style: 'thin',
color: { rgb: '000000' }
},
bottom: {
style: 'thin',
color: { rgb: '000000' }
},
left: {
style: 'thin',
color: { rgb: '000000' }
},
right: {
style: 'thin',
color: { rgb: '000000' }
}
},
// fill: {
// fgColor: { rgb: "00a2ff" },
// },
font: {
sz: 11,
},
bold: true,
numFmt: 0
}
// 單元格寬度
data["!cols"].push({ wpx });
// 根據(jù)不同行添加單元格背景顏色
let color = ''
let num = Number(key.slice(1))
if (num < 12) {
color = 'f8cbad'
} else if (num >= 12 && num < 22) {
color = '70ad47'
} else if (num >= 22 && num < 26) {
color = '00b0f0'
} else if (num >= 26 && num < 29) {
color = 'fff2cc'
} else if (num >= 29 && num < 44) {
color = 'a9d08e'
} else {
color = 'bfbfbf'
}
data[key].s.fill = { fgColor: { rgb: color, patternType: 'solid' } }
}
}
}
}
//給合并行列賦值樣式
function addRangeBorder (range, ws) {
let cols = ["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"];
range.forEach(item => {
let style = {
s: {
border: {
top: {
style: 'thin',
color: { rgb: '000000' }
},
bottom: {
style: 'thin',
color: { rgb: '000000' }
},
left: {
style: 'thin',
color: { rgb: '000000' }
},
right: {
style: 'thin',
color: { rgb: '000000' }
}
}
}
}
// 處理合并行
for (let i = item.s.c; i <= item.e.c; i++) {
ws[`${cols[i]}${Number(item.e.r) + 1}`] = ws[`${cols[i]}${Number(item.e.r) + 1}`] || style
// 處理合并列
for (let k = item.s.r + 2; k <= item.e.r + 1; k++) {
ws[cols[i] + k] = ws[cols[k] + item.e.r] || style
}
}
})
return ws;
}
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
}調(diào)用:
exportExcelByDom(document.getElementById('custom-table'), '生產(chǎn)日?qǐng)?bào)表.xlsx')
然后下面是我開(kāi)發(fā)的表格長(zhǎng)這個(gè)樣子:


上面兩種圖片是一個(gè)表格哈,比較長(zhǎng),其實(shí)下面還有,然后導(dǎo)出的效果是這樣子:

到此這篇關(guān)于Vue使用xlsx和xlsx-style導(dǎo)出表格出現(xiàn)部分樣式缺失的問(wèn)題解決的文章就介紹到這了,更多相關(guān)Vue導(dǎo)出表格樣式缺失內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- vue3如何實(shí)現(xiàn)在style中使用響應(yīng)式變量
- Vue3如何利用xlsx、xlsx-js-style導(dǎo)出Excel表格使用(適合新手)
- Vue3中使用styled-components的實(shí)現(xiàn)
- 在 Vue3 中如何使用 styled-components
- vue使用xlsx庫(kù)和xlsx-style庫(kù)導(dǎo)入導(dǎo)出excel、設(shè)置單元格背景色、文字居中、合并單元格、設(shè)置列寬
- 使用Vue綁定class和style樣式的幾種寫(xiě)法總結(jié)
- vue如何在style標(biāo)簽中使用變量(數(shù)據(jù))詳解
- 在VUE style中使用data中的變量的方法
- 在vue中:style 的使用方式匯總
相關(guān)文章
使用vue2.6實(shí)現(xiàn)抖音【時(shí)間輪盤(pán)】屏保效果附源碼
前段時(shí)間看抖音,有人用時(shí)間輪盤(pán)作為動(dòng)態(tài)的桌面壁紙,一時(shí)間成為全網(wǎng)最火的電腦屏保,后來(lái)小米等運(yùn)用市場(chǎng)也出現(xiàn)了【時(shí)間輪盤(pán)】,有點(diǎn)像五行八卦,感覺(jué)很好玩,于是突發(fā)奇想,自己寫(xiě)一個(gè)網(wǎng)頁(yè)版小DEMO玩玩,需要的朋友可以參考下2019-04-04
Vue生命周期activated之返回上一頁(yè)不重新請(qǐng)求數(shù)據(jù)操作
這篇文章主要介紹了Vue生命周期activated之返回上一頁(yè)不重新請(qǐng)求數(shù)據(jù)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07
vue2.0實(shí)現(xiàn)的tab標(biāo)簽切換效果(內(nèi)容可自定義)示例
這篇文章主要介紹了vue2.0實(shí)現(xiàn)的tab標(biāo)簽切換效果,結(jié)合實(shí)例形式分析了vue.js實(shí)現(xiàn)內(nèi)容可自定義的tab點(diǎn)擊切換功能相關(guān)操作技巧,需要的朋友可以參考下2019-02-02
Vue中在data里面調(diào)用method方法的實(shí)現(xiàn)
這篇文章主要介紹了Vue中在data里面調(diào)用method方法的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06
vue3 組合式API defineEmits() 與 emits 組
在Vue中,defineEmits()是Vue3組合式API中用于聲明自定義事件的,而emits選項(xiàng)則用于Vue2和Vue3的選項(xiàng)式API中,defineEmits()允許使用字符串?dāng)?shù)組或?qū)ο笮问铰暶魇录?emits選項(xiàng)也支持這兩種形式,且驗(yàn)證函數(shù)可以驗(yàn)證事件參數(shù),這兩種方法都是為了更規(guī)范地在組件間通信2024-09-09
vue頁(yè)面不能根據(jù)路徑進(jìn)行跳轉(zhuǎn)的解決方法
本文主要介紹了vue頁(yè)面不能根據(jù)路徑進(jìn)行跳轉(zhuǎn)的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-12-12

