el-table表頭根據(jù)內(nèi)容自適應(yīng)完美解決表頭錯(cuò)位和固定列錯(cuò)位
將代碼復(fù)制到指令中即可使用。通過指令方式進(jìn)行調(diào)用。(使用方式 <el-table v-tableFit></el-table>)
通過計(jì)算文字的寬度進(jìn)行表頭設(shè)置,其他內(nèi)容無法計(jì)算。
5000個(gè)單元格以上根據(jù)實(shí)際情況使用以上根據(jù)實(shí)際情況使用,因?yàn)閱卧裨蕉?,?jì)算時(shí)間越長(zhǎng)。
盡量使用v-if,不然有些情況下會(huì)計(jì)算錯(cuò)誤。
Vue.directive("tableFit", { //指令所在組件的 VNode 及其子 VNode 全部更新后調(diào)用。 componentUpdated(el, binding, vnode) { setTimeout(() => { adjustColumnWidth(el, vnode); }, 0) }, }); function adjustColumnWidth(table, vnode) { //中文和全角正則 const CN = new RegExp("[\u4E00-\u9FA5]|[^\uFF00-\uFFFF]"); const NUM = new RegExp("[0-9]"); //中文字體的像素寬度比例 const CN_RATE = 1.1 //數(shù)字字體的像素寬度比例 const NUM_RATE = 0.65 //其他字體的像素寬度比例 const OTHER_RATE = 0.5 const columns = vnode.child.columns.slice() //el-table通過colgroup標(biāo)簽設(shè)置html寬度 const colgroup = table.querySelector("colgroup"); const colDefs = [...colgroup.querySelectorAll("col")]; //忽略 設(shè)置了寬度 序號(hào) 多選框 的列 //判斷gutter是否已存在 const gutter = colgroup.querySelector(`col[name=gutter]`) const gutterx = colgroup.querySelector(`col[name=gutterx]`) let except = 0 if (gutter || gutterx) { //刪除gutter colDefs.pop() } //若有序號(hào) 多選框則刪除 except = colDefs.length - columns.length colDefs.splice(0, except) for (let i = columns.length - 1; i >= 0; i--) { if (columns[i].width) { colDefs.splice(i, 1) columns.splice(i, 1) } } //設(shè)置每列寬度 colDefs.forEach((col, index) => { //colgroup中 和 表頭標(biāo)簽的class名相同 通過class尋找相同列 const clsName = col.getAttribute("name"); const cells = [ ...table.querySelectorAll(`.el-table__body-wrapper td.${clsName}`), ...table.querySelectorAll(`th.${clsName}`), ]; const widthList = cells.map((el) => { const cell = el.querySelector(".cell") if (cell) { let fontSize = parseInt(window.getComputedStyle(cell,null).fontSize) fontSize = fontSize ? fontSize : 14 let width = 0 //計(jì)算每個(gè)字符的寬度 for(let str of cell.innerText) { if(CN.test(str)) { width += fontSize * CN_RATE }else if(NUM.test(str)) { width += fontSize * NUM_RATE }else { width += fontSize * OTHER_RATE } } return Math.ceil(width) } else { return 0 } }); //取一列中的最大寬度 const max = Math.max(...widthList); if (max !== 0) { //在表格數(shù)據(jù)中設(shè)置minWidth 防止尺寸變化重新計(jì)算原來的寬度 //20 + 2 20 是cell類的padding 2 是給予額外空間 columns[index].minWidth = max + 22 table.querySelectorAll(`col[name=${clsName}]`).forEach((el) => { el.setAttribute("width", max + 22); }); } }); //設(shè)置完后調(diào)用el-table方法更新布局 vnode.child.doLayout() tableRevise(table) }
修正表格表頭,固定列錯(cuò)位
沒有錯(cuò)位的可以忽略
//修正el-table錯(cuò)位 function tableRevise(table) { const tableWrapper = table.querySelector('.el-table__body-wrapper') const tableBody = table.querySelector('.el-table__body') const colgroup = table.querySelector("colgroup"); /** * (以下數(shù)值為滾動(dòng)條高度,可以自己根據(jù)情況通過class重新修改) */ //內(nèi)容大于容器時(shí) if (tableBody.clientWidth > tableWrapper.offsetWidth) { //設(shè)置x軸滾動(dòng) tableWrapper.style.overflowX = 'auto' //解決固定列錯(cuò)位 (沒有錯(cuò)位的可以忽略以下內(nèi)容) let fixedWrap = table.querySelectorAll('.el-table .el-table__fixed-body-wrapper') if (fixedWrap.length > 0) { fixedWrap.forEach(item => { item.style.paddingBottom = 8 + 'px' }) } //解決固定列覆蓋滾動(dòng)條 let fixed_left = table.querySelector('.el-table .el-table__fixed') let fixed_right = table.querySelector('.el-table .el-table__fixed-right') if (fixed_left) { fixed_left.style.height = 'calc(100% - 8px)' } if (fixed_right) { fixed_right.style.height = 'calc(100% - 8px)' } //解決表頭偏移 //沒有原生的gutter時(shí)自己新增一個(gè) const gutter = colgroup.querySelector(`col[name=gutter]`) const gutterx = colgroup.querySelector(`col[name=gutterx]`) if (!gutter && !gutterx) { let col = document.createElement('col') col.setAttribute('name', 'gutterx') col.setAttribute('width', '8') colgroup.appendChild(col) } } }
到此這篇關(guān)于el-table表頭根據(jù)內(nèi)容自適應(yīng)完美解決表頭錯(cuò)位和固定列錯(cuò)位 的文章就介紹到這了,更多相關(guān)el-table 自適應(yīng)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue中ts無法識(shí)別引入的vue文件,提示找不到xxx.vue模塊的解決
這篇文章主要介紹了vue中ts無法識(shí)別引入的vue文件,提示找不到xxx.vue模塊的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09vue2.0項(xiàng)目集成Cesium的實(shí)現(xiàn)方法
這篇文章主要介紹了vue2.0項(xiàng)目集成Cesium的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07UNIapp實(shí)現(xiàn)局域網(wǎng)內(nèi)在線升級(jí)的操作方法
這篇文章主要介紹了UNIapp實(shí)現(xiàn)局域網(wǎng)內(nèi)在線升級(jí)的操作方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-03-03Vue-cli中post請(qǐng)求發(fā)送Json格式數(shù)據(jù)方式
這篇文章主要介紹了Vue-cli中post請(qǐng)求發(fā)送Json格式數(shù)據(jù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04不同場(chǎng)景下Vue中虛擬列表實(shí)現(xiàn)
虛擬列表用來解決大數(shù)據(jù)量數(shù)據(jù)渲染問題,由于一次性渲染性能低,所以誕生了虛擬列表渲染,下面我們就來學(xué)習(xí)一下不同場(chǎng)景下Vue中虛擬列表是如何實(shí)現(xiàn)的吧2023-10-10vue2+element-ui使用vue-i18n進(jìn)行國(guó)際化的多語言/國(guó)際化詳細(xì)教程
這篇文章主要給大家介紹了關(guān)于vue2+element-ui使用vue-i18n進(jìn)行國(guó)際化的多語言/國(guó)際化的相關(guān)資料,I18n是Vue.js的國(guó)際化插件,項(xiàng)目里面的中英文等多語言切換會(huì)使用到這個(gè)東西,需要的朋友可以參考下2023-12-12從零開始實(shí)現(xiàn)Vue簡(jiǎn)單的Toast插件
這篇文章主要給大家介紹了如何從零開始實(shí)現(xiàn)Vue簡(jiǎn)單的Toast插件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-12-12vue3+electron12+dll開發(fā)客戶端配置詳解
本文將結(jié)合實(shí)例代碼,介紹vue3+electron12+dll客戶端配置,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-06-06