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;
}
}
}