【实战】Flex布局-上下自适应

经典的布局场景上下固定、中间填充剩余空间。

思路

将 Flex 主轴设为垂直方向(column),通过 flex: 1 让中间区域自动填充剩余空间,上下区域固定高度或由内容自动撑开。

原理

  1. 父容器设置
    display: flex
    flex-direction: column - 垂直方向排列
    min-height: 100vh- 确保容器至少占满整个视口高度
  2. 顶部 / 底部区域设置固定高度(如 50px),不指定高度由内容自动撑开。
  3. 中间区域设置 flex: 1,自动占据父容器剩余高度;
  4. overflow-y: auto - 内容超出时显示滚动条

示例

html 复制代码
<header class="header">头部</header>
  <main class="main">内容区</main>
  <footer class="footer">底部</footer>
</div>
css 复制代码
* {
  margin: 0;
  padding: 0;
}
 
html, body {
  height: 100%;
}
 
.container {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
 
.header {
  /* 头部高度由内容决定,不设固定高度 */
  background: #333;
  color: white;
  padding: 20px;
}
 
.main {
  flex: 1;  /* 关键:这将使主内容区填充剩余空间 */
  padding: 20px;
  overflow-y: auto; /* 内容过多时可滚动 */
}
 
.footer {
  background: #333;
  color: white;
  padding: 20px;
}

浏览器兼容性

Flex 布局在现代浏览器中有很好的支持(IE10+),如需兼容旧版浏览器,可考虑使用传统方法作为降级方案。

相关推荐
bjzhang7511 分钟前
使用 HTML + JavaScript 实现组织架构图
前端·javascript·html·组织架构图
军军君0124 分钟前
Three.js基础功能学习十六:智能黑板实现实例三
前端·javascript·css·vue.js·3d·前端框架·threejs
海上彼尚29 分钟前
SVG矢量图形快速入门
前端·html5
嗷o嗷o36 分钟前
Android App Functions 深入理解
前端
UXbot43 分钟前
AI原型设计工具评测:从创意到交互式Demo,5款产品全面解析
前端·ui·设计模式·ai·ai编程·原型模式
落魄江湖行44 分钟前
硅基同事埋的坑,我用2小时才填平:Nuxt 4 路由踩坑:可选参数 [[id]] 与 [id] 的区别
前端
一勺菠萝丶1 小时前
管理后台使用手册在线预览与首次登录引导弹窗实现
java·前端·数据库
军军君011 小时前
Three.js基础功能学习十四:智能黑板实现实例一
前端·javascript·css·typescript·前端框架·threejs·智能黑板
小村儿1 小时前
连载05-Claude Skill 不是抄模板:真正管用的 Skill,都是从实战里提炼出来的
前端·后端·ai编程
xiaotao1311 小时前
JS new 操作符完整执行过程
开发语言·前端·javascript·原型模式