使用css做出折叠导航栏的功能

实现原理:

利用隐藏的复选框记录点击状态,通过CSS选择器 :checked 和相邻兄弟选择器控制导航菜单的显示/隐藏。

html代码如下:

javascript 复制代码
<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <style>
        /* 隐藏复选框 */
        #nav-toggle { display: none; }

        /* 汉堡菜单样式 */
        .toggle-label {
            display: block;
            cursor: pointer;
            padding: 15px;
            background: #333;
            color: white;
            font-size: 24px;
        }

        /* 导航菜单 - 默认隐藏 */
        .nav-menu {
            max-height: 0;
            overflow: hidden;
            transition: max-height 0.5s ease-out;
            background: #f1f1f1;
        }

        /* 当复选框选中时显示菜单 */
        #nav-toggle:checked ~ .nav-menu {
            max-height: 300px; /* 需大于菜单总高度 */
        }
    </style>
</head>
<body>
    <!-- 使用label关联隐藏的checkbox -->
    <label for="nav-toggle" class="toggle-label">☰</label>
    <input type="checkbox" id="nav-toggle">
    
    <!-- 导航菜单 -->
    <nav class="nav-menu">
        <ul>
            <li><a href="#">首页</a></li>
            <li><a href="#">产品</a></li>
            <li><a href="#">服务</a></li>
            <li><a href="#">关于我们</a></li>
            <li><a href="#">联系方式</a></li>
        </ul>
    </nav>
</body>
</html>

页面如下:

相关推荐
王莎莎-MinerU5 小时前
Agent 时代,科学数据 API 需要重新设计
大数据·前端·数据库·人工智能·个人开发
jingling5555 小时前
自建技术博客实战(三):工具专栏——地图定位、声音复刻与 rembg 抠图
android·开发语言·前端·ai·nextjs
小小小小宇5 小时前
Chrome 插件在新开页生效
前端
橘子味的冰淇淋~5 小时前
优化前端性能之从“全局引入”改为“按需引入”
前端·javascript·vue.js
沐灵洛6 小时前
构建 Mac App Store 应用须知(全)
前端
KaMeidebaby6 小时前
卡梅德生物技术快报|蛋白修饰调控 NETosis 分子机制及实验研究进展
前端·数据库·人工智能·算法·百度
颜进强6 小时前
Claude Code -16 文件引用与加载机制完整实践:从 CLAUDE.md 到 Skills 与 Subagents
前端·后端·ai编程
2501_940041746 小时前
硬核全栈开发命题,覆盖高并发/实时/微服务
前端
风骏时光牛马6 小时前
Bash变量未加双引号导致文件名含空格解析异常实战案例
前端
Vennn6 小时前
Android自动化:使用 Web 方式实现某音未读消息检查与采集
前端·javascript·vue.js