Мой первоначальный пост был плохо сформулирован, поэтому я решил упростить свой вопрос и попробовать его снова.(Приносим извинения за неудобства!)
У меня есть контейнер DIV (фиксированная высота), и я хочу разместить стол вертикально внутри.Таблица имеет фиксированные заголовки и прокручиваемый текст.Я хочу, чтобы тело автоматически настроилось на высоту окружающего контейнера (за исключением thead).
.tbody {height: auto;}
К сожалению, ничего не делает.Знаете ли вы о какой-то хитрости (flexbox?) Для достижения моей цели?
Пожалуйста, ознакомьтесь с прикрепленными файлами / codepen в качестве отправной точки ...
CodePen
body {
display: flex;
justify-content: center;
align-items: center;
width: 100vw;
height: 100vh;
}
.container { /* wrapper element for table */
width: 20%;
height: 20%;
background-color: lightcoral;
border: 3px solid black;
}
.tableX {
width: 100%;
border-collapse: collapse;
table-layout: fixed;
text-align: left;
border: 1px dotted black;
}
.tableX thead {
display: block;
color: white;
background-color: darkgray;
}
.tableX tbody {
display: block;
overflow-y: auto;
color: black;
height: 100px; /* ----> this is the problem, I don't want a fixed height... */
}
.tableX tr {
height: 1.5rem;
}
<!DOCTYPE html>
<head>
<meta charset="utf-8">
<title>TableTerror</title>
<link rel="stylesheet" href="tableTerror.css">
</head>
<body>
<div class="container">
<table class="tableX">
<thead>
<tr>
<th>Company</th>
<th>Contact</th>
<th>Country</th>
</tr>
</thead>
<tbody>
<tr>
<td>first company</td>
<td>first name</td>
<td>first place</td>
</tr>
<tr>
<td>some company</td>
<td>some name</td>
<td>some place</td>
</tr>
<tr>
<td>some company</td>
<td>some name</td>
<td>some place</td>
</tr>
<tr>
<td>some company</td>
<td>some name</td>
<td>some place</td>
</tr>
<tr>
<td>last company</td>
<td>last name</td>
<td>last place</td>
</tr>
</tbody>
</table>
</div>
</body>
</html>
PS: Меня не волнует (атм) ширина столбца, стиль полосы прокрутки и т. Д.