0

0

如何在Flex容器中固定两列,实现中间列滚动

花韻仙語

花韻仙語

发布时间:2025-11-21 11:31:01

|

924人浏览过

|

来源于php中文网

原创

如何在Flex容器中固定两列,实现中间列滚动

本文旨在详细讲解如何在flexbox布局中实现一个经典三列布局,其中左右两侧列保持固定并占满整个视口高度,而中间内容区域则允许独立滚动。我们将深入探讨如何巧妙运用css的`position: sticky`属性结合视口单位`vh`,以构建一个兼具功能性和良好用户体验的布局方案,并提供完整的代码示例及注意事项。

布局挑战与需求分析

在现代Web开发中,实现复杂布局是常见需求。其中一种挑战是在一个弹性容器(Flex Container)中,需要将部分子元素固定在视口中,而其他子元素则可以随页面滚动。具体场景是构建一个三列布局:左右两列(A和C)需要始终保持在屏幕上,高度与视口一致,不随页面滚动而移动;而中间列(B)则包含大量内容,需要能够独立滚动。

传统的position: fixed或position: absolute在处理这种场景时存在局限性。fixed元素会脱离文档流,定位时需要精确的left、right值,这在外部元素宽度不确定或需要响应式布局时变得困难。absolute元素则相对于其最近的定位祖先,如果祖先元素本身滚动,absolute元素也会随之滚动,无法满足固定需求。此外,display: flex作为容器的布局方式也必须被保留。

核心解决方案:position: sticky与vh单位

解决上述挑战的关键在于结合使用CSS的position: sticky属性和视口高度单位vh。

  1. position: sticky:

    • position: sticky是一种混合定位模式,它结合了position: relative和position: fixed的特性。元素在未达到指定滚动阈值时表现为relative,一旦滚动到阈值,则表现为fixed,固定在视口中。
    • 配合top: 0(或bottom、left、right),可以指定元素在何时开始“粘滞”。在本例中,top: 0意味着当元素滚动到距离视口顶部0像素时,它将固定在那里。
    • 重要前提:sticky元素必须在其可滚动的父容器内。如果父容器没有滚动条,或者其overflow属性设置为hidden、scroll或auto(且内容没有溢出),sticky效果可能不生效。在本例中,我们希望左右两列相对于body的滚动而固定,因此它们将“粘滞”在视口中。
  2. 100vh 单位:

    • vh(viewport height)是一个相对单位,1vh等于视口高度的1%。因此,height: 100vh意味着元素的高度将精确等于当前视口的高度。这确保了左右两列始终占满整个屏幕高度。

逐步实现

下面我们将通过具体的HTML结构和CSS样式来构建这个布局。

1. HTML 结构

我们采用一个简单的三列Flex容器结构:




    
    
    Flex容器中固定两列
    


    
A
固定列
B
可滚动内容

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.

...

知了追踪
知了追踪

AI智能信息助手,智能追踪你的兴趣资讯

下载

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

...

相关专题

更多
css
css

css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

522

2023.06.15

css居中
css居中

css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。

262

2023.07.27

css如何插入图片
css如何插入图片

cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

753

2023.07.28

css超出显示...
css超出显示...

在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。

539

2023.08.01

css字体颜色
css字体颜色

CSS中,字体颜色可以通过属性color来设置,用于控制文本的前景色,字体颜色在网页设计中起到很重要的作用,具有以下表现作用:1、提升可读性;2、强调重点信息;3、营造氛围和美感;4、用于呈现品牌标识或与品牌形象相符的风格。

757

2023.08.10

什么是css
什么是css

CSS是层叠样式表(Cascading Style Sheets)的缩写,是一种用于描述网页(或其他基于 XML 的文档)样式与布局的标记语言,CSS的作用和意义如下:1、分离样式和内容;2、页面加载速度优化;3、实现响应式设计;4、确保整个网站的风格和样式保持统一。

604

2023.08.10

css三角形怎么写
css三角形怎么写

CSS可以通过多种方式实现三角形形状,本专题为大家提供css三角形怎么写的相关教程,大家可以免费体验。

560

2023.08.21

css设置文字颜色
css设置文字颜色

CSS(层叠样式表)可以用于设置文字颜色,这样做有以下好处和优势:1、增加网页的可视化效果;2、突出显示某些重要的信息或关键字;3、增强品牌识别度;4、提高网页的可访问性;5、引起不同的情感共鸣。

391

2023.08.22

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

20

2026.01.15

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 19.2万人学习

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

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