html - 具有高度的 flexbox:100% 不适用于 chrome 72+
问题描述
检查下面的片段。
html, body {
height: 100%;
margin: 0;
}
.flex {
height: 100%;
display: flex;
flex-direction: column;
}
.body {
height: 100%;
}
nav {
overflow: hidden;
flex-shrink: 0;
display: flex;
flex-direction: row;
}
.holder {
display: flex;
flex-direction: column;
height: initial !important;
flex: 1;
}
.wrapper {
flex: 1;
display: flex;
min-height: 0;
overflow-y: auto;
}
<div class="body">
<div class="flex"><!---->
<nav style="height: 40px; background-color: blue"></nav>
<!---->
<div class="holder body">
<div class="wrapper">
<div>
<div class="holder">
<div>
<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br>v
</div>
</div>
</div>
</div>
<div>
<div style="height: 60px; background-color: red"></div>
</div>
</div>
</div>
</div>
如果你在 chrome 71- 上运行它,上面的代码片段没有正文滚动,只能.wrapper
滚动。但是 chrome 72+ 上的同一页面有正文滚动。
EDIT
Origin question 也有quirks mode的问题。<!doctype html>
即使在 chrome 72+ 上,没有这个问题的意思也可以正常工作。
解决方案
在 chrome 72+ 上,您需要在.holder
. 这在 72 之前的版本上不是必需的。
html, body {
height: 100%;
margin: 0;
}
.flex {
height: 100%;
display: flex;
flex-direction: column;
}
.body {
height: 100%;
}
nav {
overflow: hidden;
flex-shrink: 0;
display: flex;
flex-direction: row;
}
.holder {
display: flex;
flex-direction: column;
height: initial !important;
flex: 1;
min-height: 0;
}
.wrapper {
flex: 1;
display: flex;
min-height: 0;
overflow-y: auto;
}
<div class="body">
<div class="flex"><!---->
<nav style="height: 40px; background-color: blue"></nav>
<!---->
<div class="holder body">
<div class="wrapper">
<div>
<div class="holder">
<div>
<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>v<br><br><br><br><br><br><br><br><br><br><br><br>v<br><br>v
</div>
</div>
</div>
</div>
<div>
<div style="height: 60px; background-color: red"></div>
</div>
</div>
</div>
</div>
推荐阅读
- python - 基于 pandas df 中不同值的累积计数
- android - 在 onMapReady 内部,毕加索第一次没有加载图像
- c# - 在 ViewModel 中访问 Xamarin.Forms
- featuretools - 新功能的 dtypes 是什么?
- null - Cognos Analytics:使用 null 或 0 值运行差异
- c# - 实体框架的“/”应用程序中的服务器错误
- r - 根据每列的中位数将数据框一分为二
- android - 自定义 SDK - API 级别
- java - 如果发现已知错误(异常),是否应该打印堆栈跟踪?
- c# - 开发团队中带有服务总线触发器的 Azure Functions V2