解决Grid布局下el-table自适应缩小失败的问题

1.遇到的问题:

使用了ElementPlus的el-table组件,同时将该组件用在了grid布局下。

拖动浏览器窗口,视口宽度变大时,el-table的宽度会跟着一起变大,但视口缩小时,表格不会跟着一起缩小,而是固定了当前的宽度,导致内容溢出。

2.现象:

1.原始状态:红色区域200px,蓝色区域minmax(auto, 1fr),绿色区域300px;

2.浏览器视口宽度变大:表格会跟着一起变大

3.浏览器视口宽度缩小:表格宽度固定,内容溢出

3.原始代码
html 复制代码
<template>
  <div class="wrap">
    <div class="bg-red-500">1</div>
    <div class="bg-blue-500">
      <div>
      <el-table :data="data">
        <el-table-column label="日期1" prop="date"></el-table-column>
        <el-table-column label="日期2" prop="date"></el-table-column>
        <el-table-column label="日期3" prop="date"></el-table-column>
        <el-table-column label="日期4" prop="date"></el-table-column>
      </el-table>
      </div>
    </div>
    <div class="bg-green-500">3</div>
  </div>
</template>

<script lang="ts" setup>
import { ref } from 'vue'

const data = ref([
  { date: '2016-05-02' },
  { date: '2016-05-04' },
  { date: '2016-05-01' },
  { date: '2016-05-03' }, 
])

</script>

<style lang="less" scoped>
.wrap {
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-columns: 200px minmax(auto, 1fr) 300px;

}
</style>
4.问题出在哪里?

关键就在于中间列的minmax(auto, 1fr),以及el-table对于自身最小宽度的计算,产生了影响。

当视口放大时,el-table重新计算最小宽度,此时最小内容宽度不断变大。

当我们开始缩小视口宽度时,grid列的最小宽度是由auto计算出来的,而auto默认等于子元素的最小内容宽度,所以列宽就不能比表格最小内容宽度更小。

所以中间列的宽度才无法变小。

5.解决方案

直接给中间那一列指定最小宽度min-width: 0;

表示"我允许grid的这一列,在必要的时候变得比内容还小",此时grid的自动计算逻辑就会被打破!中间那一列的表格el-table,就可以随着父容器正常变化了!

css 复制代码
.wrap {
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-columns: 200px minmax(auto, 1fr) 300px;
  .table-col {
    min-width: 0;
  }
}

我看到有其他文章说可以给父元素设置position:relative;,子元素设置position:absolute;。同样可以解决问题,但这样设置很显然会影响子元素的布局。它能实现是因为子元素脱离了文档流,已经不再归属于grid的管辖范围了,所以我是不太建议这么解决的。

另外补充一下,中间那一列,我们很可能也会再次定义grid布局,比如

在row方向定义三行:代码如下

html 复制代码
<template>
  <div class="wrap">
    <div class="bg-red-500">1</div>
    <div class="table-col bg-blue-500">
      <div>
        <el-table :data="data">
          <el-table-column label="日期1" prop="date"></el-table-column>
          <el-table-column label="日期2" prop="date"></el-table-column>
          <el-table-column label="日期3" prop="date"></el-table-column>
          <el-table-column label="日期4" prop="date"></el-table-column>
        </el-table>
      </div>
      <div class="bg-[#000]">123456</div>
      <div class="bg-[#000]">7890</div>
    </div>
    <div class="bg-green-500">3</div>
  </div>
</template>

<script lang="ts" setup>
import { ref } from 'vue'

const data = ref([
  { date: '2016-05-02' },
  { date: '2016-05-04' },
  { date: '2016-05-01' },
  { date: '2016-05-03' }, 
])


</script>

<style lang="less" scoped>
.wrap {
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-columns: 200px minmax(auto, 1fr) 300px;
  .table-col {
    min-width: 0;
    display: grid;
    grid-template-rows: 300px 200px 200px;
    gap: 8px;
  }
}
</style>

el-table,加了一层div,此时表格也会溢出的

这是因为min-width不是定义在表格的父元素了。

这个时候要改的就是给el-table的父元素再加一个min-width: 0;即可解决问题!

css 复制代码
.wrap {
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-columns: 200px minmax(auto, 1fr) 300px;
  .table-col {
    min-width: 0;
    display: grid;
    grid-template-rows: 300px 200px 200px;
    gap: 8px;
    .table-col-1 {
      min-width: 0;
    }
  }
}
相关推荐
米丘2 小时前
微前端之 Web Components 完全指南
微服务·html
秃头网友小李2 天前
前端难点:keep-alive 缓存什么?RouterView 的 key 为什么要带 scopeId?
前端·vue.js
徐小夕2 天前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法
奋斗吧程序媛3 天前
补充一个小知识点:有关@click.native
前端·vue.js
英勇无比的消炎药3 天前
一行命令背后:TinyRobot CLI 如何重构 AI 对话接入的效率范式
vue.js·aigc
Metaphor6923 天前
使用 Python 将 PDF 转换为 HTML
python·pdf·html
jay神3 天前
基于 FastAPI + Vue 的宠物领养管理系统
前端·vue.js·python·毕业设计·fastapi·宠物
一杯奶茶¥3 天前
水果销售网站 CRM客户信息管理系统 超市管理系 酒店管理系统 健身房管理系统 在线音乐网站 校园招聘系统
java·vue.js·spring boot·mysql·spring·java项目
英勇无比的消炎药3 天前
一站式搞定品牌风格:TinyRobot 主题定制从入门到精通
vue.js
a1117763 天前
“黑夜流星“个人引导页 网页html
java·前端·html