0

0

如何使用 Flexbox 实现视口内自适应高度的可滚动内容区

心靈之曲

心靈之曲

发布时间:2026-02-26 17:50:02

|

585人浏览过

|

来源于php中文网

原创

如何使用 Flexbox 实现视口内自适应高度的可滚动内容区

本文介绍如何利用 css flexbox 布局,让页面中带固定头部和底部的容器主体区域自动填充剩余视口高度,并支持内容溢出时的垂直滚动。

本文介绍如何利用 css flexbox 布局,让页面中带固定头部和底部的容器主体区域自动填充剩余视口高度,并支持内容溢出时的垂直滚动。

在构建具有固定页眉(header)和页脚(footer)的单页应用或数据表格界面时,一个常见需求是:主体内容区(body)应占据视口剩余全部高度,并在内容超出时启用滚动,而非撑开页面或导致布局断裂。传统百分比或 calc() 方案难以应对 header/footer 高度动态变化的场景,而 Flexbox 提供了简洁、健壮且语义清晰的解决方案。

核心思路是将外层容器设为 display: flex 且 flex-direction: column,并赋予 height: 100vh;header 和 footer 使用固定高度(或 flex-shrink: 0 保证不被压缩),而 body 则通过 flex: 1 占据所有剩余空间——该声明等价于 flex-grow: 1; flex-shrink: 1; flex-basis: 0,确保其弹性拉伸至可用空间,同时配合 overflow-y: auto 实现智能滚动(仅当内容超限时才显示滚动条)。

以下是完整实现代码:

PHP与MySQL程序设计3
PHP与MySQL程序设计3

本书是全面讲述PHP与MySQL的经典之作,书中不但全面介绍了两种技术的核心特性,还讲解了如何高效地结合这两种技术构建健壮的数据驱动的应用程序。本书涵盖了两种技术新版本中出现的最新特性,书中大量实际的示例和深入的分析均来自于作者在这方面多年的专业经验,可用于解决开发者在实际中所面临的各种挑战。 本书内容全面深入,适合各层次PHP和MySQL开发人员阅读,既是优秀的学习教程,也可用作参考手册。

下载
<div class="container">
  <div class="header">Header</div>
  <div class="body" id="body"></div>
  <div class="footer">Footer</div>
</div>
.container {
  display: flex;
  flex-direction: column;
  height: 100vh; /* 充满整个视口高度 */
}

.header,
.footer {
  flex-shrink: 0; /* 防止被 flex 压缩(即使未设固定 height 也安全) */
  background-color: #ffeb3b;
  padding: 16px;
}

.header { height: 100px; }
.footer { height: 100px; }

.body {
  flex: 1;            /* 关键:占据所有剩余空间 */
  overflow-y: auto;    /* 内容超长时启用滚动,不超时不显示滚动条 */
  background-color: #f5f5f5;
}

.row {
  background-color: #f44336;
  color: white;
  padding: 12px 16px;
  margin: 0 0 4px 0;
  border-radius: 4px;
}
const body = document.getElementById('body');

const createFakeData = (id) => {
  const row = document.createElement('div');
  row.textContent = `Row ${id}`;
  row.classList.add('row');
  body.appendChild(row);
};

for (let i = 0; i < 100; i++) {
  createFakeData(i);
}

关键优势与注意事项:

  • flex: 1 比 height: calc(100vh - 200px) 更鲁棒:即使 header/footer 高度由内容动态决定(如多行文本、图片加载后重排),Flexbox 仍能自动重分配空间;
  • overflow-y: auto 优于 scroll:避免始终显示空白滚动条,提升用户体验;
  • 建议为 .header 和 .footer 显式添加 flex-shrink: 0,防止在极端窄屏或字体缩放下被意外压缩;
  • 若需兼容 IE10+,注意 flex: 1 在旧版中需写为 -ms-flex: 1(现代项目通常无需考虑);
  • 不要对 .body 设置 height 或 max-height —— 这会覆盖 flex 的弹性行为,导致滚动失效或布局错乱。

通过这一模式,你可轻松构建响应迅速、结构清晰、维护成本低的全高布局,适用于后台管理面板、实时日志查看器、无限滚动列表等多种场景。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
overflow什么意思
overflow什么意思

overflow是一个用于控制元素溢出内容的属性,当元素的内容超出其指定的尺寸时,overflow属性可以决定如何处理这些溢出的内容。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1828

2024.08.15

flex教程
flex教程

php中文网为大家带来了flex教程合集,Flex是采用Flex布局的元素,称为Flex容器(flex container),简称"容器",它的所有子元素自动成为容器成员,有三个核心概念: flex项,需要布局的元素;flex容器,其包含flex项;排列方向,这决定了flex项的布局方向。php中文网还为大家带来flex的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

367

2023.06.14

Golang 实际项目案例:从需求到上线
Golang 实际项目案例:从需求到上线

《Golang 实际项目案例:从需求到上线》以真实业务场景为主线,完整覆盖需求分析、架构设计、模块拆分、编码实现、性能优化与部署上线全过程,强调工程规范与实践决策,帮助开发者打通从技术实现到系统交付的关键路径,提升独立完成 Go 项目的综合能力。

1

2026.02.26

Golang Web 开发路线:构建高效后端服务
Golang Web 开发路线:构建高效后端服务

《Golang Web 开发路线:构建高效后端服务》围绕 Go 在后端领域的工程实践,系统讲解 Web 框架选型、路由设计、中间件机制、数据库访问与接口规范,结合高并发与可维护性思维,逐步构建稳定、高性能、易扩展的后端服务体系,帮助开发者形成完整的 Go Web 架构能力。

3

2026.02.26

Golang 并发编程专题:掌握多核时代的核心技能
Golang 并发编程专题:掌握多核时代的核心技能

《Golang 并发编程专题:掌握多核时代的核心技能》系统讲解 Go 在并发领域的设计哲学与实践方法,深入剖析 goroutine、channel、调度模型与并发安全机制,结合真实场景与性能思维,帮助开发者构建高吞吐、低延迟、可扩展的并发程序,全面提升多核时代的工程能力。

5

2026.02.26

batoto漫画官网入口与网页版访问指南
batoto漫画官网入口与网页版访问指南

本专题系统整理batoto漫画官方网站最新可用入口,涵盖最新官网地址、网页版登录页面及防走失访问方式说明,帮助用户快速找到batoto漫画官方平台,稳定在线阅读各类漫画内容。

353

2026.02.25

Steam官网正版入口与注册登录指南_新手快速进入游戏平台方法
Steam官网正版入口与注册登录指南_新手快速进入游戏平台方法

本专题系统整理Steam官网最新可用入口,涵盖网页版登录地址、新用户注册流程、账号登录方法及官方游戏商店访问说明,帮助新手玩家快速进入Steam平台,完成注册登录并管理个人游戏库。

77

2026.02.25

TypeScript全栈项目架构与接口规范设计
TypeScript全栈项目架构与接口规范设计

本专题面向全栈开发者,系统讲解基于 TypeScript 构建前后端统一技术栈的工程化实践。内容涵盖项目分层设计、接口协议规范、类型共享机制、错误码体系设计、接口自动化生成与文档维护方案。通过完整项目示例,帮助开发者构建结构清晰、类型安全、易维护的现代全栈应用架构。

35

2026.02.25

Python数据处理流水线与ETL工程实战
Python数据处理流水线与ETL工程实战

本专题聚焦 Python 在数据工程场景下的实际应用,系统讲解 ETL 流程设计、数据抽取与清洗、批处理与增量处理方案,以及数据质量校验与异常处理机制。通过构建完整的数据处理流水线案例,帮助开发者掌握数据工程中的性能优化思路与工程化规范,为后续数据分析与机器学习提供稳定可靠的数据基础。

14

2026.02.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号