css - div 延伸到其父级高度的 100%,而不是仅仅填充其余空间,但仅在子级溢出时
问题描述
首先是一些上下文:
我正在尝试创建一个可滚动的内容区域。实际上,这是一个 React 应用程序,它将使用数据库中的记录异步填充可滚动区域。但以下内容足以说明我面临的问题,这纯粹是与样式相关的。
我有以下html结构:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
</head>
<body>
<div class="app">
<header class="main-head">The header</header>
<nav class="main-nav">
</nav>
<article class="content">
<div class="component">
<div>just here as a placeholder to whatever pushes the div below down</div>
<div class="table-view">
<div class="table-content-wrapper">
<div class="table-content" style="height:1410px;">
scrollable rows go here
</div>
</div>
</div>
</div>
</article>
<footer class="main-footer">The footer</footer>
</div>
</body>
</html>
以及伴随的 CSS
index
* {
box-sizing: border-box;
}
body {
width: 100vw;
height: 100vh;
margin: 0px;
padding: 0px;
}
.main-head {
min-width: 0;
min-height: 0;
border: 1px solid #ccc;
grid-area: header;
}
.content {
min-width: 0;
min-height: 0;
border: 1px solid #ccc;
grid-area: content;
}
.main-nav {
min-width: 0;
min-height: 0;
border: 1px solid #ccc;
grid-area: nav;
}
.main-footer {
min-width: 0;
min-height: 0;
border: 1px solid #ccc;
grid-area: footer;
}
.app {
display: grid;
grid-gap: 20px;
grid-template-areas: "header" "nav" "content" "footer";
grid-template-rows: 1fr 1fr 10fr 1fr;
width: 100%;
height: 100%;
overflow: hidden;
}
@media (min-width: 700px) {
.app {
grid-template-columns: 1fr 5fr;
grid-template-rows: 2fr 25fr 1fr;
grid-template-areas: "header header" "nav content" "footer footer"
}
nav ul {
flex-direction: column;
}
}
.component {
height:100%;
display:flex;
flex-flow:column;
}
.table-view {
height:100%;
width:100%;
border: 1px solid #ccc;
background: #fff;
display:flex;
flex-flow:column;
}
.table-content-wrapper {
flex: 1;
overflow: auto;
}
.table-content {
position: relative;
overflow: hidden;
width: 100%;
min-height: 100%;
}
问题在于表格的内容。
首先:注意table-content div
. 这是由 React 应用程序动态设置的,以便在数据集上创建准确的滚动条,table-content-wrapper div
并且基于数据集包含的记录总数乘以设置的行高。
问题是何时table-content-wrapper
处于溢出模式,即当记录多于可用高度显示时。这使得table-view div
拉伸到 的总高度component div
,而不是仅占用仍然可用的高度(即:高度减去高度)。component div
component div
placeholder div
这很容易通过运行这个 fiddle并查看当你从table-content div
. 您会看到 的高度table-view div
随后被 占用的高度减小,placeholder div
因此现在准确地保持在content article
元素的范围内。但显然没有更多的滚动。
所以我想这个问题归结为:我如何使它table-view div
不会超出 中可用的空间component div
,同时允许table-content-wrapper div
使用显式高度样式处于溢出模式?
更新 1
根据第一条评论,这似乎是无法在浏览器 X 中重现的情况;所以这里有一些额外的说明:
解决方案
推荐阅读
- c# - 读取 CSV 文件并转换为转置表
- java - 使用 bytebuddy 更改对参数的方法访问
- c - 在 C 中扫描和打印 char 变量
- mysql - 获取mysql中没有数据或空值的表列
- scala - scala中getOrElse的用途是什么
- c# - Visual Studio 无法启动程序访问被拒绝
- javascript - fs.readFile 不是函数
- wordpress - 问:如何在 NGINX SSL 反向代理后面的官方 Wordpress Container 中配置 Apache
- numpy - Numpy最小二乘解决方案不准确的结果
- python - 来自文件夹的 Python 循环副本在 linux 中有效,但在 win 系统中无效