Flex-1 布局实现内部滚动条

一、核心区别

‌min-h-0‌ ‌shrink-0‌
‌作用‌ 允许内容压缩(纵向控制) 禁止自身收缩(横向控制)
‌场景‌ 内部滚动条生效 固定宽度/高度不压缩

二、实战案例:多层滚动控制

目标:页面分三部分(顶部固定 + 中间滚动区 + 底部固定),确保滚动仅发生在中间区域,外层不滚动。

css 复制代码
export default function Page() {
  return (
    // 外层:固定高度 + 隐藏滚动
    <div className="flex flex-col h-screen overflow-hidden">
      
      {/* 1. 顶部固定(禁止压缩) */}
      <header className="h-20 bg-yellow-200 shrink-0">顶部导航</header>
      
      {/* 2. 中间区域:占满剩余空间 */}
      <div className="flex-1 min-h-0 flex flex-col"> 
        
        {/* 中间内部标题(固定高度) */}
        <div className="h-12 bg-gray-200 shrink-0">筛选栏</div>
        
        {/* 滚动内容区(核心) */}
        <div className="flex-1 min-h-0 overflow-y-auto">
          <div className="h-[2000px] bg-blue-100">超长内容</div>
        </div>
        
        {/* 底部固定(禁止压缩) */}
        <footer className="h-16 bg-gray-200 shrink-0">底部信息</footer>
      </div>
    </div>
  );
}

三、关键配置解析(注释版)

less 复制代码
// 外层容器(门卫)
<div className="h-screen overflow-hidden">  // ← ① 锁死高度,禁止外溢
  <div className="shrink-0">...</div>      // ← ② 固定块用shrink-0

  <div className="flex-1 min-h-0">          // ← ③ 剩余空间分配+允许压缩
    <div className="overflow-y-auto">      // ← ④ 滚动交给最内层
      <div className="h-[2000px]">...</div>// ← ⑤ 超长内容触发滚动
    </div>
  </div>
</div>

四、常见问题速查

  1. 为何外层要加 overflow-hidden? → 防止内部内容撑开页面,强制滚动仅在内层发生
  2. 为何中间层要同时用 flex-1min-h-0? → flex-1 分配剩余空间,min-h-0 覆盖默认最小高度,允许内容压缩
  3. 什么时候用 shrink-0? → 侧边栏、固定头尾等不需要随容器收缩的元素
相关推荐
LaughingZhu9 小时前
Product Hunt 每日热榜 | 2026-05-21
前端·人工智能·经验分享·chatgpt·html
怕浪猫9 小时前
Electron 开发实战(一):从零入门核心基础与环境搭建
前端·electron·ai编程
小鹏linux10 小时前
Ubuntu 22.04 部署开源免费具有精美现代web页面的Casdoor账号管理系统
linux·前端·ubuntu·开源·堡垒机
前端若水11 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
Bigger11 小时前
mini-cc:一个轻量级 AI 编程助手的诞生
前端·ai编程·claude
涵涵(互关)11 小时前
Naive-ui树型选择器只显示根节点
前端·ui·vue
BY组态11 小时前
Ricon组态系统最佳实践:从零开始构建物联网监控平台
前端·物联网·iot·web组态·组态
BY组态12 小时前
Ricon组态系统vs传统组态软件:为什么选择新一代Web组态平台
前端·物联网·iot·web组态·组态
SoaringHeart12 小时前
Flutter进阶:OverlayEntry 插入图层管理器 NOverlayZIndexManager
前端·flutter
放下华子我只抽RuiKe512 小时前
React 从入门到生产(四):自定义 Hook
前端·javascript·人工智能·深度学习·react.js·自然语言处理·前端框架