在css中如何实现布局元素自动填充剩余空间

来源:Python编程网作者:小菜鸟头衔:草根站长
导读:本期聚焦于小伙伴创作的《在css中如何实现布局元素自动填充剩余空间》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《在css中如何实现布局元素自动填充剩余空间》有用,将其分享出去将是对创作者最好的鼓励。

在CSS布局开发中,让元素自动填充剩余空间是非常常见的需求,比如侧边栏固定宽度、主内容区自适应撑满剩余宽度,或者顶部导航固定高度、下方内容区自动填充剩余高度等场景,都需要用到对应的布局技巧。不同的CSS布局方案有不同的实现方式,下面逐一介绍。

使用flex布局实现剩余空间填充

flex布局是目前最常用的自适应布局方案,通过给父容器设置display: flex,再给需要填充剩余空间的元素设置flex: 1属性,就能让该元素自动占据剩余空间。flex属性是flex-growflex-shrinkflex-basis的简写,默认值为0 1 auto,当设置为flex: 1时,等价于flex-grow: 1; flex-shrink: 1; flex-basis: 0%,元素会按照剩余空间的比例分配空间。

水平方向剩余空间填充示例

实现左侧固定200px宽度,右侧内容区自动填充剩余宽度的布局:

<!-- HTML结构 -->
<div class="flex-container">
  <div class="sidebar">侧边栏</div>
  <div class="main-content">主内容区</div>
</div>

<!-- CSS样式 -->
<style>
.flex-container {
  display: flex;
  width: 100%;
  height: 300px;
  border: 1px solid #ccc;
}
.sidebar {
  width: 200px;
  background-color: #f0f0f0;
}
.main-content {
  flex: 1;
  background-color: #e6f7ff;
}
</style>

垂直方向剩余空间填充示例

实现顶部导航固定60px高度,下方内容区自动填充剩余高度的布局:

<!-- HTML结构 -->
<div class="flex-vertical-container">
  <div class="header">顶部导航</div>
  <div class="content">内容区域</div>
</div>

<!-- CSS样式 -->
<style>
.flex-vertical-container {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 500px;
  border: 1px solid #ccc;
}
.header {
  height: 60px;
  background-color: #f0f0f0;
}
.content {
  flex: 1;
  background-color: #e6f7ff;
}
</style>

使用grid布局实现剩余空间填充

grid布局是二维布局方案,同样可以很方便地实现剩余空间填充,通过grid-template-columnsgrid-template-rows属性设置轨道尺寸,使用fr单位表示剩余空间分配比例。

水平方向剩余空间填充示例

同样实现左侧固定200px,右侧填充剩余空间的布局:

<!-- HTML结构 -->
<div class="grid-container">
  <div class="sidebar">侧边栏</div>
  <div class="main-content">主内容区</div>
</div>

<!-- CSS样式 -->
<style>
.grid-container {
  display: grid;
  grid-template-columns: 200px 1fr;
  width: 100%;
  height: 300px;
  border: 1px solid #ccc;
}
.sidebar {
  background-color: #f0f0f0;
}
.main-content {
  background-color: #e6f7ff;
}
</style>

垂直方向剩余空间填充示例

实现顶部固定60px,下方填充剩余高度:

<!-- HTML结构 -->
<div class="grid-vertical-container">
  <div class="header">顶部导航</div>
  <div class="content">内容区域</div>
</div>

<!-- CSS样式 -->
<style>
.grid-vertical-container {
  display: grid;
  grid-template-rows: 60px 1fr;
  width: 100%;
  height: 500px;
  border: 1px solid #ccc;
}
.header {
  background-color: #f0f0f0;
}
.content {
  background-color: #e6f7ff;
}
</style>

两种方案对比与适用场景

flex布局更适合一维方向的布局,比如单行或单列的线性排列,使用起来更灵活,兼容性也更好,支持IE10及以上版本。grid布局适合二维布局,能同时处理行和列的分配,语法更简洁,适合复杂的网格类布局,但兼容性稍差,不支持IE浏览器。

如果只需要处理单个方向的剩余空间填充,两种方案都可以,根据项目兼容性要求选择即可。如果是简单的自适应布局,flex布局是更通用的选择。

注意事项

  • 使用flex布局时,如果父容器没有设置明确的高度,子元素的flex: 1在垂直方向可能无法生效,需要给父容器设置高度。
  • grid布局中的fr单位是分配剩余空间,不是固定比例,如果其他轨道有固定尺寸,剩余空间才会按照fr的比例分配。
  • 如果填充剩余空间的元素内部有固定尺寸的内容,需要注意内容溢出问题,可以配合overflow属性处理。

CSSflex_layoutgrid_layout剩余空间填充修改时间:2026-06-20 09:51:31

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。