關(guān)于element-ui表頭吸附問(wèn)題的解決方案
前幾天我接到一個(gè)需求說(shuō):數(shù)據(jù)過(guò)多滑動(dòng)表格的時(shí)候,看不到表頭不知道對(duì)應(yīng)的數(shù)據(jù)是什么,用戶(hù)體驗(yàn)操作不友好,要改成表頭固定住。我當(dāng)時(shí)聽(tīng)到這個(gè)需求都要炸裂了,因?yàn)槲覀儽砀裼玫氖荅lement Ui,框架不支持啊??! 難道要把所有表格都替換成自己手寫(xiě)的嗎,這個(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-06
vue?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-09
koa2+vue實(shí)現(xiàn)登陸及登錄狀態(tài)判斷
這篇文章主要介紹了koa2+vue實(shí)現(xiàn)登陸及登錄狀態(tài)判斷,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-08-08
vue v-on:click傳遞動(dòng)態(tài)參數(shù)的步驟
這篇文章主要介紹了vue v-on:click傳遞動(dòng)態(tài)參數(shù)的步驟,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09
Vue+Microapp實(shí)現(xiàn)微前端的示例詳解
這篇文章主要為大家詳細(xì)介紹了如何實(shí)現(xiàn)以vite+vue3+Microapp為主應(yīng)用,以vue2+element為子應(yīng)用的微前端,感興趣的小伙伴快跟隨小編一起學(xué)習(xí)一下吧2023-06-06
Vant的安裝和配合引入Vue.js項(xiàng)目里的方法步驟
這篇文章主要介紹了Vant的安裝和配合引入Vue.js項(xiàng)目里的方法步驟,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12
解決Vue編譯時(shí)寫(xiě)在style中的路徑問(wèn)題
下面小編就為大家?guī)?lái)一篇解決Vue編譯時(shí)寫(xiě)在style中的路徑問(wèn)題。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09

