Vue 3 中使用 Element Plus 的 `el-table` 組件實(shí)現(xiàn)自適應(yīng)高度
在 Vue 3 中使用 Element Plus 的 `el-table` 組件實(shí)現(xiàn)自適應(yīng)高度,你可以根據(jù)容器的高度動(dòng)態(tài)設(shè)置表格的高度。通常的做法是監(jiān)聽窗口大小的變化,并相應(yīng)地調(diào)整表格的高度。
以下是一個(gè)示例代碼,展示了如何實(shí)現(xiàn)這一功能:
1. 安裝 Element Plus(如果還沒有安裝):
npm install element-plus --save # 或者 yarn add element-plus
2. 創(chuàng)建一個(gè) Vue 組件,并實(shí)現(xiàn) `el-table` 的自適應(yīng)高度:
<template> <div ref="tableContainer" class="table-container"> <el-table :data="tableData" :height="tableHeight" style="width: 100%" > <el-table-column prop="date" label="日期" width="180"></el-table-column> <el-table-column prop="name" label="姓名" width="180"></el-table-column> <el-table-column prop="address" label="地址"></el-table-column> </el-table> </div> </template> <script> import { ref, onMounted, onUnmounted } from 'vue'; import { ElTable, ElTableColumn } from 'element-plus'; export default { components: { ElTable, ElTableColumn, }, setup() { const tableData = ref([ { date: '2016-05-02', name: '王小虎', address: '上海市普陀區(qū)金沙江路 1518 弄' }, { date: '2016-05-04', name: '王小虎', address: '上海市普陀區(qū)金沙江路 1517 弄' }, // 更多數(shù)據(jù)... ]); const tableContainer = ref(null); const tableHeight = ref(0); const updateTableHeight = () => { if (tableContainer.value) { // 計(jì)算表格的高度 const containerRect = tableContainer.value.getBoundingClientRect(); const containerHeight = containerRect.height; tableHeight.value = containerHeight - 20; // 減去一些邊距或標(biāo)題欄的高度 } }; // 監(jiān)聽窗口大小變化 const handleResize = () => { updateTableHeight(); }; onMounted(() => { updateTableHeight(); // 初始化時(shí)計(jì)算一次高度 window.addEventListener('resize', handleResize); }); onUnmounted(() => { window.removeEventListener('resize', handleResize); }); return { tableData, tableHeight, tableContainer, }; }, }; </script> <style scoped> .table-container { height: 100vh; /* 你可以根據(jù)需要調(diào)整這個(gè)值 */ overflow: auto; } </style>
解釋
- <el-table>:Element Plus 提供的表格組件。
- :height="tableHeight":綁定表格的高度,使其可以根據(jù) `tableHeight` 的值動(dòng)態(tài)變化。
- tableContainer:引用了包含表格的容器,用于獲取其高度。
- updateTableHeight:計(jì)算并更新表格的高度。
- handleResize:處理窗口大小變化的函數(shù),調(diào)用 `updateTableHeight` 來更新表格高度。
- onMounted:和 `onUnmounted`**:Vue 生命周期鉤子,分別在組件掛載和卸載時(shí)執(zhí)行相應(yīng)的操作。
- window.addEventListener('resize', handleResize):添加窗口大小變化事件監(jiān)聽器。
- window.removeEventListener('resize', handleResize):移除窗口大小變化事件監(jiān)聽器,避免內(nèi)存泄漏。
這樣,當(dāng)窗口大小發(fā)生變化時(shí),表格的高度會(huì)自動(dòng)調(diào)整以適應(yīng)新的窗口尺寸。你可以根據(jù)實(shí)際需求調(diào)整 `tableContainer` 的高度以及減去的邊距值。
到此這篇關(guān)于Vue 3 中使用 Element Plus 的 `el-table` 組件實(shí)現(xiàn)自適應(yīng)高度的文章就介紹到這了,更多相關(guān)Vue 3 Element Plus el-table自適應(yīng)高度內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- vue3+elementplus基于el-table-v2封裝公用table組件詳細(xì)代碼
- Vue3+Element?Plus實(shí)現(xiàn)el-table跨行顯示(非腳手架)
- vue3使用element-plus中el-table組件報(bào)錯(cuò)關(guān)鍵字'emitsOptions'與'insertBefore'分析
- Vue2+Element-ui實(shí)現(xiàn)el-table表格自適應(yīng)高度的案例
- 一文解決vue2 element el-table自適應(yīng)高度問題
- VUE2.0 ElementUI2.0表格el-table自適應(yīng)高度的實(shí)現(xiàn)方法
相關(guān)文章
詳解如何制作并發(fā)布一個(gè)vue的組件的npm包
這篇文章主要介紹了詳解如何制作并發(fā)布一個(gè)vue的組件的npm包,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-11-11Vue學(xué)習(xí)-VueRouter路由基礎(chǔ)
這篇文章主要介紹了Vue學(xué)習(xí)-VueRouter路由基礎(chǔ),路由本質(zhì)上就是超鏈接,xiamian?文章圍繞VueRouter路由的相關(guān)資料展開詳細(xì)內(nèi)容,需要的小伙伴可以參考一下,希望對(duì)你的學(xué)習(xí)有所幫助2021-12-12Vue3使用Element?Plus實(shí)現(xiàn)列表界面的方法步驟
寫后臺(tái)管理的時(shí)候會(huì)有很多列表以及相應(yīng)的條件查詢,下面這篇文章主要給大家介紹了關(guān)于Vue3使用Element?Plus實(shí)現(xiàn)列表界面的方法步驟,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-04-04vue中使用file-saver導(dǎo)出文件的全過程記錄
這篇文章主要給大家介紹了關(guān)于vue中使用file-saver導(dǎo)出文件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-02-02vue3使用defineModel實(shí)現(xiàn)父子組件雙向綁定
這篇文章主要個(gè)給大家介紹了在vue3中使用defineModel進(jìn)行父子組件中的雙向綁定,文中通過代碼示例給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-01-01