HTML折叠菜单

<html>
<head>
<meta charset="UTF-8">
    <title>Insert title here</title>
    <script type="text/javascript">
var itemHeight = 40;
var dividerHeight = 1;

function openMenu(obj) {
    menuTitleId = obj.id;
    menuId = "menu" + menuTitleId.substring(10);
    indicatorId = "indicator" + menuTitleId.substring(10);

    menu = document.getElementById(menuId);
    indicator = document.getElementById(indicatorId);
    height = menu.style.height;

    if (height == "0px" || height == "") {
        childAmount = menu.getElementsByTagName('div').length;
        dividerAmount = menu.getElementsByTagName('li').length;
        height = childAmount * itemHeight + dividerAmount * dividerHeight;
        menu.style.height = height + "px";
        indicator.style.transform = "rotate(180deg)";
    } else {
        menu.style.height = "0px";
        indicator.style.transform = "rotate(0deg)";
    }
}
</script>
<style>

.menus {
width: 320px;
overflow: hidden;
box-shadow: 1px 1px 4px gray;
/* border-bottom: 1px solid black;
border-top: 1px solid black; */
border: 1px solid gray;
border-radius: 5px;
}

.menu {
overflow: hidden;
height: 0px;
transition: all 0.3s ease;
}

.menu_title {
width: 305px;
height: 50px;
line-height: 50px;
background: #fafafa;
color: gray;
font-size: 20px;
padding-left: 15px;
transition: all 0.3s ease;
cursor: pointer;
position: relative;
font-weight: bold;
overflow: hidden;
}

.menu_title:hover {
background: #dedede;
color: black;
}

.indicator {
width: 50px;
height: 50px;
font-weight: bold;
position: absolute;
right: 0px;
top: 0px;
transition: all 0.3s ease;
font-weight: bold;
text-align: center;
}

.item {
width: 290px;
height: 40px;
line-height: 40px;
background: gray;
color: white;
padding-left: 30px;
transition: all 0.3s ease;
cursor: pointer;
overflow: hidden;
}

.item:hover {
background: #B22222;
}

.item a {
width: 290px;
height: 40px;
display: block;
text-decoration: none;
color: white;
text-decoration: none;
}

.item_divider {
width: 322px;
height: 1px;
background: white;
display: block;
opacity: 0.8;
}

.menu_divider {
width: 100%;
height: 1px;
background: gray;
}

</style>
</head>
<body>

<div class="menus">

    <div id="menu_title1" class="menu_title" onclick="openMenu(this)">
        Menu1
        <div class="indicator" id="indicator1">^</div>
    </div>
    <div class="menu" id="menu1">
        <div class="item">
            <a href="#">Item1</a>
        </div>
        <li class="item_divider"></li>
        <div class="item">
            <a href="#">Item2</a>
        </div>
        <li class="item_divider"></li>
        <div class="item">
            <a href="#">Item3</a>
        </div>
        <li class="item_divider"></li>
        <div class="item">
            <a href="#">Item4</a>
        </div>
    </div>

    <li class="menu_divider"></li>

    <div id="menu_title2" class="menu_title" onclick="openMenu(this)">
        Menu2
        <div class="indicator" id="indicator2">^</div>
    </div>
    <div class="menu" id="menu2">
        <div class="item">
            <a href="#">Item1</a>
        </div>
        <li class="item_divider"></li>
        <div class="item">
            <a href="#">Item2</a>
        </div>
    </div>

    <li class="menu_divider"></li>

    <div id="menu_title3" class="menu_title" onclick="openMenu(this)">
        Menu3
        <div class="indicator" id="indicator3">^</div>
    </div>
    <div class="menu" id="menu3">
        <div class="item">
            <a href="#">Item1</a>
        </div>
        <li class="item_divider"></li>
        <div class="item">
            <a href="#">Item2</a>
        </div>
        <li class="item_divider"></li>
        <div class="item">
            <a href="#">Item3</a>
        </div>
    </div>
</div>
</body>
</html>

这里写图片描述

  • 8
    点赞
  • 48
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
实现HTML折叠菜单栏可以使用HTML、CSS和JavaScript。下面是一个简单的示例代码: HTML: ```html <nav class="nav"> <ul> <li> <a href="#">菜单项1</a> <ul> <li><a href="#">子菜单项1</a></li> <li><a href="#">子菜单项2</a></li> <li><a href="#">子菜单项3</a></li> </ul> </li> <li><a href="#">菜单项2</a></li> <li><a href="#">菜单项3</a></li> </ul> </nav> ``` CSS: ```css .nav ul { margin: 0; padding: 0; list-style: none; } .nav li { position: relative; margin: 0; padding: 0; } .nav a { display: block; padding: 10px; background-color: #f7f7f7; color: #333; text-decoration: none; } .nav a:hover { background-color: #ddd; } .nav ul ul { display: none; position: absolute; top: 100%; left: 0; background-color: #f7f7f7; z-index: 999; } .nav ul ul li { display: block; width: 100%; } .nav ul ul a { padding: 10px; color: #333; } .nav ul ul a:hover { background-color: #ddd; } ``` JavaScript: ```javascript var nav = document.querySelector('.nav'); var navItems = nav.querySelectorAll('li'); for (var i = 0; i < navItems.length; i++) { var navItem = navItems[i]; var subNav = navItem.querySelector('ul'); if (subNav) { navItem.classList.add('has-subnav'); navItem.addEventListener('click', function(event) { event.preventDefault(); if (this.classList.contains('active')) { this.classList.remove('active'); } else { var activeNavItem = nav.querySelector('.active'); if (activeNavItem) { activeNavItem.classList.remove('active'); } this.classList.add('active'); } }); } } ``` 以上代码实现了一个具有折叠效果的菜单栏,点击菜单项时可以展开或折叠其子菜单。需要注意的是,CSS中的绝对定位和JavaScript中的类名操作都是用来控制菜单项的展开和折叠的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值