一个有趣的CSS题目

前几天无意间看到一个有趣的题,题目很简单,但是最终的结果却出人意料,题目是这样的:

xml 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="theme-color" content="blue"/>
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<style>
  .parent{
    display: flex;
    flex-direction: column;
    height: 600px;
    width: 300px;
    background-color: aqua;
  }
  .header{
    height: 200px;
    background-color: red;
  }
  .fotter{
    height: 200px;
    background-color: blue;
  }
  .content{
    height: 100%;
  }
</style>
<body>
  <div class="parent">
    <div class="header"></div>
    <div class="content"></div>
    <div class="fotter"></div>
  </div>
</body>
</html>

这段代码中的content的高度是多少,大家可以自己想一下,稍微思考一下。接下来让我们看一下豆包的回答: ​ 再看一下通义千问的回答:

再看一下deepseek的回答:

最后再看看Gemini3的回答:

大家可能以为content的高度不就是200px吗,但是结果真的是这样的吗?

请大家看一下最终的结果:

大家会看到content的高度为360px,header和footer的高度为120px,是不是感觉不可思议,为啥会这样嘞,这个问题,想问ai就会发现,这咋问啊,ai全是错的,那我来告诉你们答案(当然我说的也不一定对,但是大差不差,结果肯定是对的):

  • percent height 会被解析为父容器的绝对值:content 的 height:100% → 600px(父高度)。
  • 每个子项的 flex base size(假设基准)分别是 header=200, content=600, footer=200,总和 = 1000px。
  • 可用主轴空间 = 600px,差额(需要收缩) = 1000 - 600 = 400px。
  • 默认 flex-shrink = 1,按基准尺寸比例收缩:content 收缩量 = 600/1000 * 400 = 240 → 最终 content 高度 = 600 - 240 = 360px。

参考(建议重点看 W3C 规范里的算法):

大家可以详细看看理解一下,当然不看也没关系,知道这个计算规则也 可以了,至少比ai强了。

相关推荐
万少2 小时前
HarmonyOS 开发必会 5 种 Builder 详解
前端·harmonyos
橙序员小站4 小时前
Agent Skill 是什么?一文讲透 Agent Skill 的设计与实现
前端·后端
炫饭第一名7 小时前
速通Canvas指北🦮——基础入门篇
前端·javascript·程序员
王晓枫7 小时前
flutter接入三方库运行报错:Error running pod install
前端·flutter
符方昊7 小时前
React 19 对比 React 16 新特性解析
前端·react.js
ssshooter7 小时前
又被 Safari 差异坑了:textContent 拿到的值居然没换行?
前端
曲折7 小时前
Cesium-气象要素PNG色斑图叠加
前端·cesium
Forever7_7 小时前
Electron 淘汰!新的桌面端框架 更强大、更轻量化
前端·vue.js
Angelial7 小时前
Vue3 嵌套路由 KeepAlive:动态缓存与反向配置方案
前端·vue.js
jiayu8 小时前
Angular学习笔记24:Angular 响应式表单 FormArray 与 FormGroup 相互嵌套
前端