关于父级设置min-height,子级的百分比height失效问题

先说结论:父元素设置min-height时,子元素的百分比高度无效

故事的开始是我想做一个全屏的背景加上一个居中的小div

类似如下效果:

于是我给body设置了background以及居中三件套:

css 复制代码
display:flex;
justify-content: center;
align-items: center;

为了让垂直方向的居中生效(body默认高度为0),又不写死body的高度(后来我想了想其实写死也没关系,不过这是题外话),于是我设置了min-height100vh。然后给子元素设置height50%

xml 复制代码
<style>
    .parent {
        margin:0;
        background-color: orange;
        display: flex;
        justify-content: center;
        align-items: center;
        min-height: 100vh;
    }
    .child {
        background-color: #fff;
        width: 200px;
        height: 50%;
    }
</style>
<body class="parent">
    <div class="child"></div>
</body>

结果页面中没有子元素,我看了看,子元素高度变成了0。

排查可能的原因后,我发现只要把bodymin-height改为height问题就解决了。

min-height存在时有两种情况,一种是父元素的实际高度大于min-height,另一种是父元素的实际高度就是min-height

依据上面的例子,我们可以得出结论:

高度不足min-height的父元素(实际高度等于min-height),其下的子元素百分比高度无效。

然后我们在测试一下第一种情况,给父元素加一个高度超过min-height的子元素。

xml 复制代码
<style>
    .parent {
        margin:0;
        background-color: orange;
        display: flex;
        justify-content: center;
        align-items: center;
        min-height: 100vh;
    }
    .parent::after {
        content: "";
        display: block;
        width: 0;
        height: 120vh;
    }
    .child {
        background-color: #fff;
        width: 200px;
        height: 50%;
    }
</style>
<body class="parent">
    <div class="child"></div>
</body>

结果如下:

可以看到右侧出现了滚动条,说明父元素是被撑开了,实际高度大于min-height,但是设置了height: 50%;的子元素高度依旧为0。

终于我们可以得出结论:

父元素设置min-height时,子元素的百分比高度无效

相关推荐
choke2336 分钟前
[特殊字符] Python 文件与路径操作
java·前端·javascript
云飞云共享云桌面8 分钟前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能
Deng94520131420 分钟前
Vue + Flask 前后端分离项目实战:从零搭建一个完整博客系统
前端·vue.js·flask
威迪斯特23 分钟前
Flask:轻量级Web框架的技术本质与工程实践
前端·数据库·后端·python·flask·开发框架·核心架构
wuhen_n1 小时前
JavaScript内置数据结构
开发语言·前端·javascript·数据结构
大鱼前端1 小时前
为什么我说CSS-in-JS是前端“最佳”的糟粕设计?
前端
不爱吃糖的程序媛1 小时前
Capacitor:跨平台Web原生应用开发利器,现已全面适配鸿蒙
前端·华为·harmonyos
AC赳赳老秦1 小时前
2026国产算力新周期:DeepSeek实战适配英伟达H200,引领大模型训练效率跃升
大数据·前端·人工智能·算法·tidb·memcache·deepseek
CHU7290351 小时前
淘宝扭蛋机抽盒小程序前端功能解析:解锁趣味抽盒新体验
前端·小程序
-凌凌漆-1 小时前
【npm】npm的-D选项介绍
前端·npm·node.js