欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue完美實現el-table列寬自適應

 更新時間:2021年05月08日 11:08:57   作者:李中凱  
這篇文章主要介紹了vue完美實現el-table列寬自適應,對vue感興趣的同學,可以參考下

背景

Element UI 是 PC 端比較流行的 Vue.js UI 框架,它的組件庫基本能滿足大部分常見的業(yè)務需求。但有時候會有一些定制性比較高的需求,組件本身可能沒辦法滿足。最近在項目里就碰到了。

很多頁面都需要用到表格組件el-table。如果沒有給el-table-column指定寬度,默認情況下會平均分配給剩余的列。在列數比較多的情況,如果el-table寬度限定在容器內,單元格里的內容就會換行。強制不換行,內容要么在單元格內滾動,要么就會溢出或被截斷。

產品想要的效果是:內容保持單行顯示,列間距保持一致,表格超出容器允許水平滾動。el-table-column是支持設置固定寬度的,在內容寬度可預知的情況下,也能滿足這個需求。問題就在于如何讓列寬動態(tài)適應內容的寬度。在官方文檔也沒找到這樣的選項,應該是組件本身不支持。

技術方案

于是想到了動態(tài)計算內容寬度的方案。網上也有人提過這個思路,做法是根據內容字符數來計算寬度。這種方法有幾個局限:

  • 內容必須是文本
  • 不同字符寬度不一,結算結果不夠準確
  • 需要在渲染前操作數據,不利于解耦

我采用了另一種思路,還是動態(tài)計算內容寬度,但是根據實際渲染后的 DOM 元素寬度,這樣就能解決上面三個問題。

具體怎么做呢?通過查看渲染后的 DOM 元素發(fā)現,el-table 的表頭和內容分別用了一個原生table,通過colgroup設置每列的寬度。就從這里入手,col的name屬性值和對應的 td的class值是一致的,這樣就可以遍歷對應列的所有單元格,找出寬度最大的單元格,用它的內容寬度加上一個邊距作為該列的寬度。

具體實現

怎么計算內容寬度呢?這是個比較關鍵的步驟。渲染后的每個單元格有個.cell類,用white-space: nowrap; overflow: auto;設置為不允許換行,內容超出后可滾動,同時設置display: inline-block;以便計算實際內容寬度。這樣,最終的寬度可通過.cell元素的scrollWidth屬性得到。

function adjustColumnWidth(table) {
  const colgroup = table.querySelector("colgroup");
  const colDefs = [...colgroup.querySelectorAll("col")];
  colDefs.forEach((col) => {
    const clsName = col.getAttribute("name");
    const cells = [
      ...table.querySelectorAll(`td.${clsName}`),
      ...table.querySelectorAll(`th.${clsName}`),
    ];
    // 忽略加了"leave-alone"類的列
    if (cells[0]?.classList?.contains?.("leave-alone")) {
      return;
    }
    const widthList = cells.map((el) => {
      return el.querySelector(".cell")?.scrollWidth || 0;
    });
    const max = Math.max(...widthList);
    const padding = 32;
    table.querySelectorAll(`col[name=${clsName}]`).forEach((el) => {
      el.setAttribute("width", max + padding);
    });
  });
}

中間的探索過程比較繁瑣,但最終的代碼實現卻非常簡潔。在什么時候觸發(fā)列寬計算呢?自然是組件渲染完成后。為了方便重用,我采用了 Vue 自定義指令的方式。

Vue.directive("fit-columns", {
  update() {},
  bind() {},
  inserted(el) {
    setTimeout(() => {
      adjustColumnWidth(el);
    }, 300);
  },
  componentUpdated(el) {
    el.classList.add("r-table");
    setTimeout(() => {
      adjustColumnWidth(el);
    }, 300);
  },
  unbind() {},
});

更進一步,我封裝了一個 Vue 插件叫v-fit-columns,已經發(fā)布到 npm 倉庫,直接安裝即可使用。
安裝:

npm install v-fit-columns --save

引入:

import Vue from 'vue';
import Plugin from 'v-fit-columns';
Vue.use(Plugin);

使用:

<el-table v-fit-columns>
  <el-table-column label="No." type="index" class-name="leave-alone"></el-table-column>
  <el-table-column label="Name" prop="name"></el-table-column>
  <el-table-column label="Age" prop="age"></el-table-column>
</el-table>

源碼倉庫在這:https://github.com/kaysonli/v-fit-columns ,歡迎各位不吝賜教和 Star!

總結

這個方案多少有點 Hack 的意味,只顧實現需求,可能在其他方面還有點瑕疵,比如渲染完后會稍微閃一下(因為要重新調整寬度,會出現 reflow)。不過從最終實現的效果來看,還算令人滿意

以上就是vue完美實現el-table列寬自適應的詳細內容,更多關于vue實現el-table列寬自適應的資料請關注腳本之家其它相關文章!

相關文章

  • npm?run?dev失敗的簡單解決辦法

    npm?run?dev失敗的簡單解決辦法

    最近工作中遇到了npm?run?dev報錯這個問題,通過查找相關資料最終解決了,所以下面這篇文章主要給大家介紹了關于npm?run?dev失敗的詳細解決辦法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-07-07
  • axios?發(fā)?post?請求,后端接收不到參數的完美解決方案

    axios?發(fā)?post?請求,后端接收不到參數的完美解決方案

    這篇文章主要介紹了axios?發(fā)?post?請求,后端接收不到參數的解決方案,場景很簡單,就是一個正常 axios post 請求,本文給大家分享問題原因分析及解決方案需要的朋友可以參考下
    2022-12-12
  • vue將單頁面改造成多頁面應用的方法

    vue將單頁面改造成多頁面應用的方法

    最近領導交我一個項目是使用 vue-cli 搭建的單頁面應用。下面小編通過本文給大家介紹vue將單頁面改造成多頁面應用的方法 ,感興趣的朋友一起看看吧
    2018-11-11
  • vue響應式原理與雙向數據的深入解析

    vue響應式原理與雙向數據的深入解析

    Vue 最獨特的特性之一,是其非侵入性的響應式系統。下面這篇文章主要給大家介紹了關于vue響應式原理與雙向數據的相關資料,需要的朋友可以參考下
    2021-06-06
  • element使用自定義icon圖標的詳細步驟

    element使用自定義icon圖標的詳細步驟

    前端經常會用到UI提供的各種圖表,推薦阿里的圖標庫,下面這篇文章主要給大家介紹了關于element使用自定義icon圖標的詳細步驟,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-11-11
  • vue?v-model的詳細講解(推薦!)

    vue?v-model的詳細講解(推薦!)

    vue中經常使用到和這類表單元素,vue對于這些元素的數據綁定和我們以前經常用的jQuery有些區(qū)別,下面這篇文章主要給大家介紹了關于vue?v-model的相關資料,需要的朋友可以參考下
    2022-04-04
  • vue3動態(tài)路由刷新出現空白頁的原因與最優(yōu)解

    vue3動態(tài)路由刷新出現空白頁的原因與最優(yōu)解

    頁面刷新白屏其實是因為vuex引起的,由于刷新頁面vuex數據會丟失,這篇文章主要給大家介紹了關于vue3動態(tài)路由刷新出現空白頁的原因與最優(yōu)解的相關資料,需要的朋友可以參考下
    2023-11-11
  • vue實現element-ui對話框可拖拽功能

    vue實現element-ui對話框可拖拽功能

    這篇文章主要介紹了vue實現element-ui對話框可拖拽功能,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-08
  • vuex actions異步修改狀態(tài)的實例詳解

    vuex actions異步修改狀態(tài)的實例詳解

    今天小編就為大家分享一篇vuex actions異步修改狀態(tài)的實例詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue實現列表固定列滾動

    vue實現列表固定列滾動

    這篇文章主要為大家詳細介紹了vue實現列表固定列滾動,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07

最新評論