Vue3+Element Plus動態表格列寬設置

在 Vue3 + Element Plus 中實現動態設置表格列寬,可以通過以下幾種方式實現:

方法 1:動態綁定 width 屬性(推薦)

vue

復制

下載

<template><el-table :data="tableData" style="width: 100%"><!-- 動態綁定 width --><el-table-columnprop="name"label="姓名":width="dynamicWidth"/><!-- 其他列 --></el-table><el-slider v-model="dynamicWidth" :min="100" :max="300" />
</template><script setup>
import { ref } from 'vue';const dynamicWidth = ref(150); // 初始寬度
const tableData = ref([{ name: '張三', age: 30 },{ name: '李四', age: 25 }
]);
</script>

方法 2:使用響應式對象管理列配置

vue

復制

下載

<template><el-table :data="tableData"><el-table-columnv-for="col in columns":key="col.prop":prop="col.prop":label="col.label":width="col.width"/></el-table><el-button @click="resizeColumn">調整第一列寬度</el-button>
</template><script setup>
import { ref } from 'vue';const columns = ref([{ prop: 'name', label: '姓名', width: 120 },{ prop: 'age', label: '年齡', width: 80 }
]);const resizeColumn = () => {columns.value[0].width = Math.floor(Math.random() * 200 + 100);
};
</script>

方法 3:結合拖拽事件動態調整(高級)

vue

復制

下載

<template><el-table :data="tableData"@header-dragend="handleResize"><el-table-columnprop="name"label="姓名(可拖拽)"width="150"resizable/><!-- 其他列 --></el-table>
</template><script setup>
const handleResize = (newWidth, oldWidth, column) => {console.log('列寬變化:', {column: column.label,oldWidth,newWidth});// 這里可以保存新的寬度到數據庫或狀態管理
};
</script>

方法 4:響應式設置最小/最大寬度

vue

復制

下載

<el-table-columnprop="email"label="郵箱":min-width="100":width="emailWidth"
/>

注意事項:

  1. 單位處理

    • 數字值默認單位為?px

    • 可使用字符串指定單位::width="'20%'"

  2. 性能優化

    vue

    復制

    下載

    <el-table :data="tableData" table-layout="fixed"><!-- 固定布局模式下寬度分配更精確 -->
    </el-table>
  3. 響應式斷點

    js

    復制

    下載

    import { useWindowSize } from '@vueuse/core';const { width } = useWindowSize();
    const dynamicWidth = computed(() => {return width.value < 768 ? 100 : 200;
    });
  4. 動態隱藏列

    vue

    復制

    下載

    <el-table-columnv-if="showColumn"prop="address"label="地址"width="200"
    />

完整示例(動態調整 + 保存配置):

vue

復制

下載

<template><el-table :data="tableData" @header-dragend="saveColumnWidth"><el-table-columnv-for="col in columns":key="col.prop"v-bind="col"resizable/></el-table>
</template><script setup>
import { ref, onMounted } from 'vue';// 列配置(從本地存儲加載或使用默認值)
const columns = ref([{ prop: 'name', label: '姓名', width: loadWidth('name', 120) },{ prop: 'age', label: '年齡', width: loadWidth('age', 80) },{ prop: 'email', label: '郵箱', width: loadWidth('email', 200) }
]);// 加載保存的寬度
function loadWidth(prop, defaultValue) {const saved = localStorage.getItem(`colWidth_${prop}`);return saved ? parseInt(saved) : defaultValue;
}// 保存列寬
const saveColumnWidth = (newWidth, oldWidth, column) => {const prop = column.property;localStorage.setItem(`colWidth_${prop}`, newWidth);
};// 表格數據
const tableData = ref([...]);
</script>

常見問題解決:

  1. 寬度不生效

    • 確保父容器有明確寬度

    • 添加 CSS:.el-table { table-layout: fixed; }

  2. 拖拽卡頓

    • 減少表格數據量

    • 使用虛擬滾動:<el-table-v2>

  3. 自適應內容寬度

    js

    復制

    下載

    const autoWidth = ref(0);
    onMounted(() => {// 根據內容計算寬度(示例)autoWidth.value = Math.max(...tableData.value.map(d => d.name.length * 10));
    });

選擇合適的方法取決于你的具體需求:

  • 簡單動態調整:使用方法 1

  • 復雜表格配置:使用方法 2

  • 需要保存用戶設置:結合 localStorage 實現

  • 響應式布局:結合窗口尺寸監聽

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/85140.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/85140.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/85140.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【JVM目前使用過的參數總結】

JVM參數總結 筆記記錄 JVM-棧相關JVM-方法區(元空間)相關JVM-堆相關 JVM-棧相關 .-XX:ThreadStackSize1M -Xss1m 上面的簡寫形式【設置棧的大小】 JVM-方法區(元空間)相關 -XX:MaxMetaspaceSize10m 【設置最大元空間大小】 JVM-堆相關 -XX:MaxHeapSize10m -Xmx10m 上面的簡寫形…

AI輔助高考志愿填報-專業全景解析與報考指南

高考志愿填報&#xff0c;這可是關系到孩子未來的大事兒&#xff01;最近&#xff0c;我親戚家的孩子也面臨著這個難題&#xff0c;昨晚一個電話就跟我聊了好久&#xff0c;問我報啥專業好。說實話&#xff0c;這問題真不好回答&#xff0c;畢竟每個孩子情況不一樣&#xff0c;…

Android Studio Windows安裝與配置指南

Date: 2025-06-14 20:07:12 author: lijianzhan 內容簡介 文章中&#xff0c;主要是為了初次接觸 Android 開發的用戶提供詳細的關于 Android Studio 安裝以及配置教程&#xff0c;涵蓋環境準備、軟件下載、安裝配置全流程&#xff0c;重點解決路徑命名、組件選擇、工作空間設置…

SpringAI+DeepSeek-了解AI和大模型應用

一、認識AI 1.人工智能發展 AI&#xff0c;人工智能&#xff08;Artificial Intelligence&#xff09;&#xff0c;使機器能夠像人類一樣思考、學習和解決問題的技術。 AI發展至今大概可以分為三個階段&#xff1a; 其中&#xff0c;深度學習領域的自然語言處理(Natural Lan…

IP5362至為芯支持無線充的22.5W雙C口雙向快充移動電源方案芯片

英集芯IP5362是一款應用于移動電源&#xff0c;充電寶&#xff0c;手機&#xff0c;平板電腦等支持無線充模式的22.5W雙向快充移動電源方案SOC芯片,集成同步升降壓轉換器、鋰電池充電管理、電池電量指示等功能。兼容全部快充協議&#xff0c;同步開關放電支持最大22.5W輸出功率…

手游剛開服就被攻擊怎么辦?如何防御DDoS?

手游新上線時遭遇DDoS攻擊是常見現象&#xff0c;可能導致服務器癱瘓、玩家流失甚至項目失敗。面對突如其來的攻擊&#xff0c;開發者與運營商需要迅速響應并建立長效防御機制。本文提供應急處理步驟與防御策略&#xff0c;助力游戲穩定運營。 一、手游開服遭攻擊的應急響應 快…

秋招是開發算法一起準備,還是只準備一個

THE LAST TIME 昨天晚上半夜有個星球的26屆的同學&#xff0c;私信問我。說目前是只準備開發還是開發算法一起準備&#xff08;兩者技術知識都挺欠缺的&#xff09; 看到這里&#xff0c;肯定有很多同學會說。馬上都該秋招了&#xff0c;還什么多線程開工&#xff0c;趕緊能住編…

web項目部署配置HTTPS遇到的問題解決方法

今天使用nginxtomcatssl完成了web項目的部署&#xff0c;本以為沒有什么問題&#xff0c;但是在頁面測試的時候又蹦出了這么一個問題&#xff0c;大致是說由于配置了HTTPS&#xff0c;但是之前的請求是通過HTTP請求的&#xff0c;所以現在被攔截&#xff0c;由于缺少某些權限信…

理解與建模彈性膜-AI云計算數值分析和代碼驗證

彈性膜在連接生物學理解和工程創新方面至關重要&#xff0c;因為它們能夠模擬軟組織力學、實現先進的細胞培養系統和促進柔性設備&#xff0c;廣泛應用于軟組織生物力學、細胞培養、生物膜建模和生物醫學工程等領域。 ??AI云計算數值分析和代碼驗證 彈性膜在連接生物學理解和…

AI大模型競賽升溫:百度發布文心大模型4.5和X1

AI大模型&#xff0c;作為智能技術的巔峰之作&#xff0c;正逐步改變著我們的生活與工作方式。近期&#xff0c;百度在AI大模型領域的最新動向&#xff0c;無疑為這場科技競賽再添一把火。3月16日&#xff0c;百度正式宣布發布文心大模型4.5及文心大模型X1&#xff0c;這兩款大…

升級OpenSSL和OpenSSH 修復漏洞

升級OpenSSL和OpenSSH 目前版本OpenSSH_7.4p1, OpenSSL 1.0.2k-fips 26 Jan 2017 升級到OpenSSH_9.8p1, OpenSSL 1.1.1u 30 May 2023 服務器CentOS Linux release 7.6.1810 (Core) 一、升級OpenSSL到1.1.1u 下載并編譯 OpenSSL&#xff08;推薦目錄 /usr/local/openssl&…

JavaSE - Object 類詳細講解

定義 是所有類的直接或者間接父類&#xff0c;是 Java 中唯一一個沒有父類的類。其中所有的方法都是可以被子類繼承的。 常用方法 equals方法&#xff1a; 比較兩個對象引用的地址值是否相同&#xff0c;默認情況下是使用 “” 進行比較&#xff0c;但是這個方法一般會被之類…

觀遠ChatBI|讓數據分析像聊天一樣簡單

BI通過收集、整合和分析企業內部的各種數據&#xff0c;幫助企業發現數據中的模式和趨勢&#xff0c;從而做出更明智的商業決策&#xff0c;以此來提升企業的經營能力和競爭力。無論是傳統BI還是自助BI&#xff0c;都是為了在數據和人之間建立一座橋梁&#xff0c;使數據能夠被…

Go語言同步原語與數據競爭:WaitGroup

在Go語言并發編程中&#xff0c;我們經常需要等待多個 goroutine 執行完畢后再繼續下一步操作。Go 提供的 sync.WaitGroup 就是專為這種**“等待一組任務完成”**而設計的同步原語。 一、基本原理 sync.WaitGroup 提供三個主要方法&#xff1a; 方法說明Add(n int)設置等待的…

Java單體架構 vs 分布式架構

Java單體架構 vs 分布式架構 在電商系統開發中&#xff0c;當用戶量從幾百激增到百萬級&#xff0c;你的架構是否還能從容應對&#xff1f;一次代碼更新是否意味著整個系統停機&#xff1f;今天我們就來拆解Java架構設計的核心命題&#xff1a;單體還是分布式&#xff1f; 一、…

day40- 硬件學習之 51單片機II (中斷處理)

一、獨立按鍵的使用 main.c key.c key.h 二、中斷處理 2.1 定義 中斷系統是為使CPU具有對外界緊急事件的實時處理能力而設置的。 當CPU正在處理某件事的時候外界發生了緊急事件請求&#xff0c;要求CPU暫停當前的工作&#xff0c;轉而去處理這個緊急事件&#xff0c;處理完以…

機器學習:開啟智能時代的大門

一、引言 機器學習&#xff08;Machine Learning&#xff09;正成為人工智能的核心技術。從 Netflix 推薦電影&#xff0c;到銀行識別欺詐交易&#xff0c;機器學習正在逐漸改變世界。本篇文章將從理論到實操全面介紹機器學習的基礎概念&#xff0c;并附有代碼和案例。 二、什…

幾個重要的行列式 線性代數

目錄 1.主&#xff08;副&#xff09;對角線行列式 2 拉普拉斯展開式 3 范德蒙德行列式 對于行列式的計算來說&#xff0c;一般給出的行列式我們都要對其進行化簡&#xff0c;但是化簡到什么程度就可以了呢&#xff1f; 這就是本篇的用處&#xff0c;一般給出的行列式化簡的…

答辯講解387基于Spring Boot的心理健康管理系統

摘 要 視頻地址 答辯講解387基于Spring Boot的心理健康管理系統_嗶哩嗶哩_bilibili 自改革開放政策施行以來&#xff0c;我國經濟持續保持快速增長態勢&#xff0c;國民生活水平得到了明顯提升&#xff0c;然而近些年來&#xff0c;經濟增速出現放緩&#xff0c;再加上疫情等…

使用WinUSB讀寫USB設備

參考&#xff1a;使用WinUSB讀寫USB設備 - USB中文網