使用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>

页面如下:

相关推荐
华仔啊4 分钟前
20个CSS实用技巧,10分钟从小白变大神!
前端·css
起名时在学Aiifox6 分钟前
Vue3 + Element Plus 表格排序实战:基于状态字段的智能排序方案
前端·javascript·vue.js·element plus
再吃一根胡萝卜9 分钟前
从 Element UI 到 Element Plus:el-table 大数据量性能为何下降了?
前端
转转技术团队12 分钟前
转转UI自动化走查方案探索
前端
yzx99101316 分钟前
基于Flask的智能语音增强系统模拟
前端·javascript·html
青衫码上行21 分钟前
【Java Web学习 | 第14篇】JavaScript(8) -正则表达式
java·前端·javascript·学习·正则表达式
草帽lufei32 分钟前
解锁AI新维度:深入体验Google Antigravity的Gemini3模型
前端·ai编程·gemini
昔人'35 分钟前
grid: auto-fit 和 auto-fill区别
css·grid
CoolerWu38 分钟前
TRAE SOLO实战:一个所见即所得的笔记软体
前端·trae
没落英雄40 分钟前
简单了解 shadowDom
前端·html