我最初的帖子措辞不当,因此我决定简化我的问题,然后再试一次。 (不便之处,敬请谅解!)
我有一个容器DIV(固定高度),并且想在其中垂直放置桌子。 该表具有固定的标题和可滚动的正文。我希望机身自动调整到周围容器的高度(减去thead)。
.tbody {height: auto;}
不幸的是什么也没做。您知道达到我目标的一些技巧吗?
请以附件/文件为起点...
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:我不在乎(atm)列宽,滚动条的样式等。
答案 0 :(得分:0)
我正在尝试复制您的图像。 这是您需要的布局吗?
body {
display: grid;
place-content: center;
height: 100vh;
}
.container {
height: 30vh;
overflow-y: scroll;
border: 3px solid black;
}
.table {
width: 30vw;
min-width: 240px;
border-collapse: collapse;
overflow-y: scroll;
display: block;
}
.table thead {
position: absolute;
background: white;
}
.table thead th {
padding-right: 10px;
}
.table tbody tr:first-child td {
padding-top: 30px;
}
.element {
background: tomato;
border: 3px solid black;
}
.element + .element {
border-top: none;
}
<div class="container">
<table class="table">
<thead>
<tr>
<th>Company</th>
<th>Contact</th>
<th>Country</th>
</tr>
</thead>
<tbody>
<tr>
<td>company one</td>
<td>name one</td>
<td>place one</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>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>