实现响应式导航栏折叠需结合CSS媒体查询、Flexbox布局和JS交互。首先在大屏用Flex横向排列导航项,小屏通过媒体查询隐藏导航列表并显示汉堡按钮,用户点击时通过JavaScript切换.active类控制菜单展开与收起,核心为“结构清晰+样式适配+轻量脚本”,确保移动端友好与流畅体验。

实现响应式导航栏折叠的关键是结合 CSS 媒体查询、Flexbox 布局和隐藏/显示机制。在小屏幕设备上,当水平空间不足时,将导航项收起为一个可点击的“汉堡菜单”,用户点击后展开导航链接。下面是一个简单实用的实现方式。
使用语义清晰的结构,包含一个用于切换的按钮和一个包裹导航链接的容器:
<nav class="navbar">
  <div class="nav-toggle" id="mobile-menu">
    <span></span>
    <span></span>
    <span></span>
  </div>
  <ul class="nav-links">
    <li><a href="#home">首页</a></li>
    <li><a href="#about">关于</a></li>
    <li><a href="#services">服务</a></li>
    <li><a href="#contact">联系</a></li>
  </ul>
</nav>
使用 Flexbox 让导航栏在大屏幕上横向排列:
.navbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #333;
  padding: 1rem;
}
.nav-links {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
}
.nav-links a {
  color: white;
  text-decoration: none;
  padding: 0.5rem 1rem;
}
在小屏幕上隐藏导航列表,并显示汉堡按钮:
立即学习“前端免费学习笔记(深入)”;
.nav-toggle {
  display: none;
  flex-direction: column;
  cursor: pointer;
}
.nav-toggle span {
  width: 25px;
  height: 3px;
  background-color: white;
  margin: 3px 0;
  transition: 0.3s;
}
@media (max-width: 768px) {
  .nav-toggle {
    display: flex;
  }
  .nav-links {
    display: none;
    flex-direction: column;
    width: 100%;
  }
  .nav-links.active {
    display: flex;
  }
}
CSS 本身无法处理点击事件,所以需要少量 JS 控制类的切换:
document.getElementById('mobile-menu').addEventListener('click', function() {
  document.querySelector('.nav-links').classList.toggle('active');
});
这样点击汉堡按钮时,nav-links 会添加或移除 active 类,从而通过 CSS 控制显示或隐藏。
基本上就这些。核心思路是:大屏用 Flex 横向布局,小屏靠媒体查询隐藏菜单,配合 JS 切换类来控制展开。整个过程流畅、兼容性好,适合大多数响应式网站使用。不复杂但容易忽略细节,比如移动端的点击区域和动画过渡效果可以进一步优化体验。
以上就是如何用css实现响应式导航栏折叠的详细内容,更多请关注php中文网其它相关文章!
                        
                        每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号