關(guān)于element-ui表頭吸附問(wèn)題的解決方案
前幾天我接到一個(gè)需求說(shuō):數(shù)據(jù)過(guò)多滑動(dòng)表格的時(shí)候,看不到表頭不知道對(duì)應(yīng)的數(shù)據(jù)是什么,用戶體驗(yàn)操作不友好,要改成表頭固定住。我當(dāng)時(shí)聽(tīng)到這個(gè)需求都要炸裂了,因?yàn)槲覀儽砀裼玫氖荅lement Ui,框架不支持啊??! 難道要把所有表格都替換成自己手寫的嗎,這個(gè)工作量太大了啦
經(jīng)過(guò)幾天幾夜的思考,大聰明的我想到了2個(gè)方案,廢話不說(shuō),直接上干貨
第一種方案:
el-table 添加height屬性,即可以實(shí)現(xiàn)頭部固定,但是這個(gè)屬性不太適合我們公司的業(yè)務(wù),因?yàn)槲覀兊暮笈_(tái)界面基本都是上部分已經(jīng)占了部分面積,到了小屏幕電腦,表格的視圖區(qū)會(huì)很少,所以這個(gè)方案我是不考慮的了
第二種方案:
就是來(lái)一個(gè)掩蓋手法,當(dāng)滑動(dòng)到一定位置時(shí),顯示另一個(gè)表頭,造成像吸頂?shù)母杏X(jué),聽(tīng)起來(lái)是不是已經(jīng)有點(diǎn)撥云見(jiàn)日了
1.因?yàn)楸眍^固定會(huì)在多個(gè)地方用到,所以弄成了組件。先創(chuàng)建一個(gè)表頭的組件pk-table-header
<template> <div id="fix-table-header" class="table-wrapper" :style="{top: `${navHeightV2}px`}"> // 這里的top是因?yàn)槲覀兒笈_(tái)頂部會(huì)有一些固定提示 <el-table :data="[]" style="width: 100%" v-bind="{...$tableClass}" class="g-table-wrapper table-header"> <template v-for="(item,index) in columns"> <el-table-column v-if="item.show" :key="index" v-bind="{...item}"> <!-- S 自定義表頭 --> <template v-if="item.type === 'custom'" slot="header"> {{ item.label }} </template> <!-- E 自定義表頭 --> </el-table-column> </template> </el-table> </div> </template> <script> // vuex import { mapState } from 'vuex'; export default { name: 'pk-table-header', props: { // 列表 columns: { type: Array, default: () => [] } }, computed: { ...mapState({ navHeightV2: (state) => state.app.navHeightV2 // 導(dǎo)航欄高度V2 }) } }; </script> <style lang="scss" scoped> .table-wrapper { position: sticky; left: 0; right: 0; z-index: 4; } .g-table-wrapper { position: relative; margin-top: -48px; border: 1px solid #ebeef5; border-bottom: 0; } .table-header { margin-top: 0; height: 48px; overflow: hidden; }
2.在utils文件里添加以下方法,因?yàn)槿绻砀裼凶鲎髠?cè)或右側(cè)固定,表格滑動(dòng)時(shí)表頭組件也要跟著滑動(dòng)
export const hanldeTableScroll = (vue) => { vue.$nextTick(() => { if (!vue.$refs.table) return; // 獲取表格實(shí)例 const tableEl = vue.$refs.table.$el; const mainTable = tableEl.querySelectorAll('.el-table__body-wrapper')[0]; // 獲取表頭組件實(shí)例 const tableHeaderEl = vue.$refs.tableHeader.$el; // 處理因?yàn)樽髠?cè)或右側(cè)固定,滑動(dòng)時(shí),表頭組件跟著滑動(dòng) mainTable.onscroll = function() { let mainTableLeft = this.scrollLeft; let fixTabel = tableHeaderEl.querySelectorAll('.el-table__body-wrapper')[0]; let mainTableHeadr = tableEl.querySelectorAll('.el-table__header-wrapper')[0]; fixTabel.scrollLeft = mainTableLeft; mainTableHeadr.scrollLeft = mainTableLeft; }; // 判斷表頭組件什么時(shí)候顯示 const rect = tableEl.getBoundingClientRect(); const top = rect.top || tableEl.offsetTop; // 這里是我們公司業(yè)務(wù)需要兼容頂部通知、到期等顯示 let stickyTop = vue.$store.state.app.navHeightV2; let shouldFixHeader = top < stickyTop; tableEl.style.zIndex = shouldFixHeader ? 0 : 5; }); };
3.下面就是要開(kāi)始使用前面兩個(gè)步驟的代碼了
引入表頭組件,引入數(shù)據(jù),引入表格方法?
- 在mounted的時(shí)候監(jiān)聽(tīng)滾動(dòng)事件?
【效果展示 】
以上就是關(guān)于element-ui表頭吸附問(wèn)題的解決方案的詳細(xì)內(nèi)容,更多關(guān)于element-ui表頭吸附的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
vue實(shí)現(xiàn)分環(huán)境打包步驟(給不同的環(huán)境配置相對(duì)應(yīng)的打包命令)
這篇文章主要介紹了vue實(shí)現(xiàn)分環(huán)境打包步驟(給不同的環(huán)境配置相對(duì)應(yīng)的打包命令),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-06-06vue?eslint報(bào)錯(cuò)error?"Component?name?"*****"
這篇文章主要給大家介紹了關(guān)于vue?eslint報(bào)錯(cuò)error?“Component?name?“*****“?should?always?be?multi-word”的解決方法,文中通過(guò)圖文以及實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09koa2+vue實(shí)現(xiàn)登陸及登錄狀態(tài)判斷
這篇文章主要介紹了koa2+vue實(shí)現(xiàn)登陸及登錄狀態(tài)判斷,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-08-08vue v-on:click傳遞動(dòng)態(tài)參數(shù)的步驟
這篇文章主要介紹了vue v-on:click傳遞動(dòng)態(tài)參數(shù)的步驟,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09Vue+Microapp實(shí)現(xiàn)微前端的示例詳解
這篇文章主要為大家詳細(xì)介紹了如何實(shí)現(xiàn)以vite+vue3+Microapp為主應(yīng)用,以vue2+element為子應(yīng)用的微前端,感興趣的小伙伴快跟隨小編一起學(xué)習(xí)一下吧2023-06-06Vant的安裝和配合引入Vue.js項(xiàng)目里的方法步驟
這篇文章主要介紹了Vant的安裝和配合引入Vue.js項(xiàng)目里的方法步驟,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12解決Vue編譯時(shí)寫在style中的路徑問(wèn)題
下面小編就為大家?guī)?lái)一篇解決Vue編譯時(shí)寫在style中的路徑問(wèn)題。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09