0

0

实现侧边导航菜单与页眉同步隐藏的滚动交互效果

花韻仙語

花韻仙語

发布时间:2026-02-22 16:10:03

|

795人浏览过

|

来源于php中文网

原创

实现侧边导航菜单与页眉同步隐藏的滚动交互效果

本文详解如何让右侧滑出式侧边导航菜单(由汉堡按钮触发)在页面向下滚动时,与固定页眉一同平滑隐藏,解决仅页眉消失而菜单滞留的问题。

本文详解如何让右侧滑出式侧边导航菜单(由汉堡按钮触发)在页面向下滚动时,与固定页眉一同平滑隐藏,解决仅页眉消失而菜单滞留的问题。

在现代响应式网页中,常采用“滚动隐藏页眉”(scroll-to-hide header)模式提升内容可视区域;但若同时存在由汉堡菜单触发的、固定定位(position: fixed)的侧边导航面板(如 .menu__box),其默认不会响应页眉的隐藏逻辑——因为两者 DOM 结构独立,CSS 类控制也未联动。本教程将带你精准同步页眉与侧边菜单的显示/隐藏状态,确保用户体验一致、专业。

✅ 核心原理:状态同步而非样式覆盖

原代码中,.nav_up 类通过 top: -500px 将页眉移出视口,但 .menu__box 本身已设置 right: -100% 控制显隐,且其 transition 和初始定位逻辑与 .nav_up 无关联。因此,直接复用 .nav_up 类到菜单上是最简洁、最符合现有架构的方案——无需修改 CSS 动画逻辑,只需扩展 JavaScript 的 DOM 操作范围。

✅ 正确实现步骤

1. 修改滚动监听逻辑(关键修复)

在原有 scroll 事件监听器中,同步操作 .menu__box 元素的 nav_up 类:

const SCROLL_THRESHOLD = 30;
let lastScrollY = window.scrollY;

window.addEventListener('scroll', () => {
  const currentScrollY = window.scrollY;
  const delta = currentScrollY - lastScrollY;

  const header = document.querySelector(".the-header");
  const menuBox = document.querySelector(".menu__box"); // ? 新增:获取菜单容器

  if (delta > 0 && delta >= SCROLL_THRESHOLD) {
    // 向下滚动 → 隐藏页眉 & 菜单
    header.classList.add("nav_up");
    menuBox.classList.add("nav_up"); // ✅ 同步添加
  } else if (delta < 0 && -delta >= SCROLL_THRESHOLD) {
    // 向上滚动 → 显示页眉 & 菜单
    header.classList.remove("nav_up");
    menuBox.classList.remove("nav_up"); // ✅ 同步移除
  }

  lastScrollY = currentScrollY;
});

2. 补充 CSS 支持(可选但推荐)

为确保 .menu__box 在隐藏时完全脱离布局影响,并保持过渡流畅,建议增强 .nav_up 的通用性:

Gaga
Gaga

曹越团队开发的AI视频生成工具

下载
/* 使 nav_up 同时适用于 header 和 menu__box */
.nav_up {
  /* 对于 .the-header:继续使用 top 移出 */
  top: -500px !important;
  /* 对于 .menu__box:改用 right 移出(更符合其原始设计) */
}
.nav_up.menu__box {
  right: -300px !important; /* 匹配其宽度,确保完全隐藏 */
  transition: right 0.5s ease-in-out;
}

? 提示:!important 在此处用于覆盖 .menu__box 原有 right: 0 !important(来自 #menu__toggle:checked ~ .menu__box),确保滚动隐藏逻辑优先级更高。若希望避免 !important,可将 .nav_up.menu__box 规则置于 CSS 文件末尾,或改用更具体的选择器(如 .menu__box.nav_up)。

3. 确保 DOM 可访问性

检查 HTML 中 .menu__box 是否始终存在于文档中(即不依赖 JS 动态插入)。当前结构合理:

<ul class="menu__box"> <!-- ✅ 静态存在,querySelector 可稳定获取 -->
  <li class="menu__item">HOMEPAGE</li>
  <!-- ... -->
</ul>

⚠️ 注意事项与最佳实践

  • 避免 display: none 方案:虽然答案中提及 display: none 是一种解法,但它会中断 CSS 过渡动画、破坏 :checked 状态下的视觉反馈,且在用户快速上下滚动时易造成菜单“闪现”。推荐使用位移类(如 right: -300px)维持动画连贯性。
  • 滚动节流优化:生产环境建议添加 requestAnimationFrame 或防抖处理,防止高频 scroll 事件影响性能:
    let ticking = false;
    window.addEventListener('scroll', () => {
      if (!ticking) {
        requestAnimationFrame(() => {
          // 执行滚动逻辑
          ticking = false;
        });
        ticking = true;
      }
    });
  • 移动端兼容性:该方案在 iOS Safari 和 Android Chrome 中均表现良好;若遇 Safari 下 fixed 元素滚动异常,可添加 body { overscroll-behavior: none; } 抑制弹性滚动干扰。

✅ 总结

让侧边导航菜单与页眉同步隐藏,本质是将单一状态(nav_up)扩展至多个相关 DOM 元素,而非重写样式或逻辑。通过两行关键 JS(获取并操作 .menu__box 元素),即可无缝集成现有滚动行为。这不仅解决了当前问题,也为后续扩展(如多级菜单、工具栏联动)提供了清晰的可维护模式。

最终效果:用户向下滚动 ≥30px 时,页眉向上滑出、侧边菜单向右滑出;向上滚动时二者同步回归——视觉统一、交互自然、代码轻量。

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

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

975

2023.08.11

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

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

800

2023.11.06

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

524

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

454

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

616

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5735

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

491

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

217

2023.09.04

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

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

1030

2026.02.13

热门下载

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

精品课程

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

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