0

0

CSS如何固定左侧菜单,右侧内容滚动_左菜单用fixed定宽定高度,右侧内容设定对应的margin-left

P粉602998670

P粉602998670

发布时间:2026-03-19 07:45:08

|

463人浏览过

|

来源于php中文网

原创

左侧fixed菜单遮挡右侧内容时,应设左侧width并用inset:0+translateZ(0),右侧用margin-left匹配宽度、min-height:100vh、height:calc(100vh-60px)+overflow-y:auto,且包裹在独立容器内。

css如何固定左侧菜单,右侧内容滚动_左菜单用fixed定宽定高度,右侧内容设定对应的margin-left

fixed 左侧菜单后,右侧内容被遮挡怎么办

根本原因是 fixed 元素脱离文档流,右侧内容默认从页面左上角开始渲染,没“让出”左侧空间。不能只靠 margin-left 硬推——如果左菜单高度超出视口、或页面缩放,margin-left 值固定就容易错位。

正确做法是:左侧用 position: fixed,右侧用 margin-left + min-height: 100vh 保证最低撑满视口,且 margin-left 必须严格等于左菜单的宽度(含 border/padding)。

  • lefttop 要显式设为 0,避免浏览器默认偏移
  • 左侧容器需设 width(如 200px),右侧对应设 margin-left: 200px
  • 右侧内容外层必须有包裹块(如 <main>),不能直接对 bodymargin-left —— 否则滚动条会出现在整个页面,而非仅内容区

右侧内容滚动失效或滚动区域异常

常见现象是:右侧内容很长,但只能滚动整个页面(包括左菜单),或者右侧完全不滚动。本质是滚动上下文没落在正确容器上。

必须确保:右侧内容区域自身可滚动,而不是依赖 body 滚动。这意味着它需要 heightmax-height + overflow-y: auto,且高度不能靠 height: 100% 向上继承——因为父级没设高时,100% 会算成 0

立即学习前端免费学习笔记(深入)”;

  • 给右侧主容器设 height: calc(100vh - 60px)(减去 header 高度),再加 overflow-y: auto
  • 避免在 htmlbody 上设 overflow: hidden,否则会截断右侧滚动
  • 如果用了 Flex 布局,右侧项要加 flex: 1 并设 min-height: 0,防止 flex item 不收缩导致滚动失效

fixed 菜单在 Safari 或移动端表现错乱

Safari 对 fixed 元素的处理更敏感,尤其在页面缩放、软键盘弹出、地址栏显示/隐藏时,常出现定位漂移或滚动卡顿。

上班人导航
上班人导航

上班人必备的职场办公导航网站

下载

关键兼容策略是:不用 top: 0 依赖视口顶部,改用 inset: 0(现代写法),并补一层 transform: translateZ(0) 强制 GPU 加速;同时禁用 iOS 的弹性滚动回弹,避免菜单跟着“晃”。

  • 左侧菜单加 inset: 0 0 0 0 替代 top/left/bottom/right: 0
  • transform: translateZ(0)will-change: transform 提升图层
  • body 上加 overscroll-behavior-y: contain,阻止滚动穿透到背景
  • 移动端慎用 vh 单位——Safari 的 100vh 在地址栏收起时会变大,推荐用 100dvh(如果支持)或 JS 动态设高

菜单高度超过视口时,底部内容不可见

fixed 元素默认不随页面滚动,但如果菜单本身有内部滚动(比如长导航列表),就必须让它自己可滚动,而不是指望用户滚整个页面去看菜单底部。

错误做法是给菜单设 height: 100vh 再加 overflow-y: auto —— 这会导致菜单滚动条和右侧内容滚动条嵌套打架。应该把菜单内容单独包一层,控制其最大高度。

  • 菜单外层设 position: fixed; top: 60px; bottom: 0; width: 200px(预留 header 高度)
  • 菜单内部内容区(如 <nav>)设 height: calc(100% - 48px)(减去 footer 或 logo 区域),再加 overflow-y: auto
  • 避免给 htmlbodyheight: 100%,否则影响子元素百分比计算

最易被忽略的一点:所有尺寸值(widthmargin-lefttopbottom)必须保持单位一致,且优先使用 px 或 rem,少用 % —— 因为 % 在 fixed 上是相对于视口宽高的,而你通常想对齐的是设计稿里的固定宽度。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
css
css

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

537

2023.06.15

css居中
css居中

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

276

2023.07.27

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

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

778

2023.07.28

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

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

568

2023.08.01

css字体颜色
css字体颜色

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

779

2023.08.10

什么是css
什么是css

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

655

2023.08.10

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

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

590

2023.08.21

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

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

408

2023.08.22

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

7

2026.03.18

热门下载

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

精品课程

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

共14课时 | 1.0万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.7万人学习

CSS教程
CSS教程

共754课时 | 44.4万人学习

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

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