0

0

CSS项目实战之多级垂直菜单_递归结构的样式设计方案

P粉602998670

P粉602998670

发布时间:2026-02-13 12:45:11

|

760人浏览过

|

来源于php中文网

原创

用 data-level 属性标记层级,padding-left 替代 margin-left 实现缩进,父级设 position: relative,::after 伪元素消除 hover 间隙,top: calc(100% + 1px),transition 明确属性,body.menu-open 控制滚动穿透,ie11 降级为 block 布局。

css项目实战之多级垂直菜单_递归结构的样式设计方案

怎么让递归生成的多级菜单真正垂直对齐且不塌陷

递归渲染的菜单常出现子菜单错位、层级缩进失效、hover 区域不连续等问题,根本原因是 CSS 没有绑定到 DOM 的嵌套深度逻辑上,而是依赖静态类名或固定层级选择器。浏览器不会因为 HTML 是递归生成的,就自动理解“第 3 层子菜单要左偏移 40px”——这得你明确定义。

实操建议:

  • data-level 属性在递归时显式标记层级(如 <ul data-level="2"></ul>),比靠 .menu ul ul ul 这种选择器更可控、可读、易调试
  • 避免用 margin-left 实现缩进:它会破坏 box-sizing: border-box 下的宽度计算,且 hover 点击热区变窄;改用 padding-left 配合 position: relative 定位子菜单容器
  • 子菜单默认 display: none,但必须确保父级 position: relative,否则 absolute 子菜单会相对 body 定位,脱离上下文

hover 展开时子菜单闪退或触发不了的 CSS 原因

这不是 JS 事件没绑好,大概率是 CSS 中 hover 触发区域和子菜单之间存在「间隙」,鼠标移过去瞬间失去 hover 状态,导致 display: none 立刻生效。

常见错误现象:ul li:hover > ul 能显示,但鼠标一动就消失;或者子菜单从顶部滑出,但底部刚露出来就收回去。

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

实操建议:

  • 在父 li 和子 ul 之间加一个透明连接块:用 ::after 伪元素撑开垂直间距,高度至少 10px,content: "" + position: absolute + top: 100%
  • 子菜单 ultop 不要用 100% 硬卡,改用 top: calc(100% + 1px),避免像素四舍五入导致的 1px 断连
  • 禁用 transition: all:它会让 display 变化被忽略,改用明确属性如 transition: opacity 0.2s, visibility 0.2s

移动端点击展开菜单时,CSS 如何避免重绘抖动和滚动穿透

纯 hover 在移动端无效,改用 :focus-within 或 JS 切换 class 是主流做法,但容易引发两个问题:页面轻微上跳(focus 触发滚动锚定)、背景内容仍可滚动(滚动穿透)。

聪豹Wiseal
聪豹Wiseal

聪豹Wiseal是一个专业的历史时间线收集整理工具

下载

使用场景:折叠菜单需要适配 iOS Safari 和 Android Chrome,且不能依赖第三方库。

实操建议:

  • 给菜单根容器加 touch-action: manipulation,减少点击延迟,同时防止误触触发双击缩放
  • 展开时给 动态加 class="menu-open",配合 body.menu-open { overflow: hidden; },比 JS 操作 scrollTop 更稳定
  • 子菜单用 transform: scaleY(0) + transform-origin: top 控制展开动画,避免 height 动画触发重排(reflow)

IE11 兼容下递归菜单的 display: flex 布局失效怎么办

IE11 对 flex 嵌套支持差,尤其当递归层级超过 2 层时,flex-direction: column 在子 ul 中可能完全不生效,菜单变成水平堆叠。

性能影响:强行用 floatinline-block 修复会导致子菜单宽度计算异常,且无法响应式收缩。

实操建议:

  • 放弃在 IE11 中对子菜单做 flex 布局,统一用 display: block + width: 100%,靠 padding-leftposition: absolute 控制位置
  • @supports (display: flex) 包裹现代写法,IE11 自动降级到 fallback 样式块
  • 避免在递归结构中使用 gapalign-items: stretch —— IE11 不识别,且无 polyfill 补救方案

最麻烦的不是写多少层 ul 样式,而是每层的 position 上下文是否干净、z-index 是否被意外截断、以及移动端 focus 状态是否被 input 失焦打断。这些细节不验证到真机,光看桌面 Chrome 开发者工具是看不出问题的。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

938

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

777

2023.11.06

css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

585

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

104

2025.10.23

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

411

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

587

2023.08.10

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

581

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

20

2025.12.06

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1

2026.02.13

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.3万人学习

CSS教程
CSS教程

共754课时 | 30.7万人学习

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

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