为什么我的el-table宽度无法自适应?

前言

最近在开发一个表格需求,用的是element-ui的el-table组件,开发好了才发现,我的el-table组件宽度无法自适应,一直都是固定的大小。

模拟代码:

html 复制代码
    <div class="table-box">
      <div>我是侧边栏1</div>
      <div>我是侧边栏2</div>
      <div>
        <el-table :data="tableData" border>
        </el-table>
      </div>
    </div>

屏幕拉升前:

屏幕拉升后:

难道el-table的宽度没有自适应? 带着疑问🤔️,我去看了element-ui的demo,它们是可以宽度自适应的。

屏幕拉升前:

屏幕拉升后:

那到底是哪里影响了?

正文

仔细对比两边的样式区别后,最后发现是我设置了flex布局,flex布局影响了。

如果把我的flex布局去掉,el-table是可以自适应的。

那为什么flex布局会影响到el-table的宽度自适应?

我们去看看el-table的源码,看看它是怎么做自适应的。

js 复制代码
 // table.vue 
if (this.fit) {
  addResizeListener(this.$el, this.resizeListener);
}
// resize-event.js
import ResizeObserver from 'resize-observer-polyfill';
export const addResizeListener = function(element, fn) {
  if (isServer) return;
  if (!element.__resizeListeners__) {
    element.__resizeListeners__ = [];
    element.__ro__ = new ResizeObserver(resizeHandler);
    element.__ro__.observe(element);
  }
  element.__resizeListeners__.push(fn);
};

通过源码可以看到,el-table是使用了resize-observer-polyfill这个库来监听el元素(**div.el-table**),当el元素宽度变化时,el-table会重新布局,实现宽度自适应。

resize-observer-polyfill内部是使用了ResizeObserver这个api实现的。

所以核心是监听$el元素的宽度变化。

我们的结构是这样的:

html 复制代码
    <div class="table-box">
      <div>我是侧边栏1</div>
      <div>我是侧边栏2</div>
      <div>
        <el-table :data="tableData" border>
        </el-table>
      </div>
    </div>

在flex布局中,如果祖先元素(.table-box)没有设置宽度,el-table的上一级div元素会被el-table的宽度撑开,如果此时el-table的宽度大于祖先元素,就会造成el-table宽度无法自适应。

所以问题的关键是怎么让div不继承el-table的宽度。

解决方案

设置overflow:auto

给el-table的上一级div元素设置overflow:auto。这样它可以继承祖先元素的宽度,然后el-table就算超出,也会有滚动条,达到自适应。

设置position:absolute和width:100%

el-table元素上级再加一个div,设置position:absolutewidth:100%。它的上级设置position:relativewidth:100%,相对它定位,这样可以继承祖先的宽度。

祖先元素设置固定宽度

如果祖先元素设置了固定宽度,这样子元素都会继承祖先元素的宽度,el-table元素就可以自适应了。

总结

如果大家遇到flex布局下,el-table宽度无法自适应,可以试试这几种解决方案。大家可以根据自己的需求选择。我推荐第一种,它比较灵活,代码也不多,兼容性好。

相关推荐
weixin_4569042716 分钟前
C# 中的回调函数
java·前端·c#
kura_tsuki31 分钟前
[Web网页] LAMP 架构与环境搭建
前端·架构
yinuo39 分钟前
UniApp+Vue3多分包引入同一 npm 库被重复打包至 vendor 的问题分析与解决
前端
码界奇点1 小时前
Spring Web MVC构建现代Java Web应用的基石
java·前端·spring·设计规范
苏打水com1 小时前
JavaScript 入门学习指南:从零基础到能写交互效果
javascript
yinuo1 小时前
UniApp + Vue3 使用 marked 报错:SyntaxError /[\p{L}\p{N}]/u 问题分析与解决
前端
大前端helloworld1 小时前
前端梳理体系从常问问题去完善-框架篇(Vue2&Vue3)
前端·javascript·面试
嫂子的姐夫2 小时前
11-py调用js
javascript·爬虫·python·网络爬虫·爬山算法
小墨宝2 小时前
web前端学习LangGraph
前端·学习
南囝coding2 小时前
React 19.2 重磅更新!这几个新特性终于来了
前端·react.js·preact