gpt4 book ai didi

javascript - 点击第三层菜单项后如何关闭菜单

转载 作者:行者123 更新时间:2023-12-01 01:49:42 24 4
gpt4 key购买 nike

如何让下面的CSS+js下拉菜单在点击第三层菜单项后关闭。现在,当我单击菜单外的任何位置时,它就会关闭。我想点击第三层菜单关闭菜单。

这是一个Fiddle示例。

HTML 代码:

 <ul class="dropdown">
<li><a href="#">Please select</a>
<ul class="sub_menu">
<li>
<a href="#">Artificial Turf</a>
<ul>
<li><a href="#" class="subMenu">Indoor</a></li>
<li><a href="#" class="subMenu">Outdoor</a></li>
</ul>
</li>
<li>
<a href="#">Batting Cages</a>
<ul>
<li><a href="#" class="subMenu">Indoor</a></li>
<li><a href="#" class="subMenu">Outdoor</a></li>
</ul>
</li>
</ul>
</li>
</ul​

CSS 代码:

/* 
LEVEL ONE
*/
ul.dropdown { position: relative;color:#333;z-index: 9999; }
ul.dropdown li { font-weight: bold; float: left; zoom: 1; position: relative; }
ul.dropdown li a { display: block; padding: 8px 8px;color:#333;text-decoration:none;}
ul.dropdown li:last-child a { border-right: none; } /* Doesn't work in IE */
ul.dropdown li.hover,ul.dropdown li:hover { background: #CCC; position: relative; text-decoration: none;}

/*
LEVEL TWO
*/
ul.dropdown ul { width: 140px; visibility: hidden; position: absolute; top: 100%; left: 0px;margin-top:0px; font-size: 12px;margin:0px;border: 1px solid #999;}
ul.dropdown ul li { font-weight: normal; background: #E5E5E5; color: #000;border-bottom: 1px solid #ccc; float: none; margin:0px;padding:0px;padding-left:5px;}

/* IE 6 & 7 Needs Inline Block */
ul.dropdown ul li a { border-right: none; width: 100%; display: inline-block;margin:0px; padding: 8px 0px;text-decoration:none;}

/*
LEVEL THREE
*/
ul.dropdown ul ul { left: 100%; top: 0; max-height: 380px; overflow: auto;width:200px;}

Javascript代码:

$(".dropdown li").click(function() { 
$(this).parent().children("li").not(this).children("ul").css({ "visibility":"hidden" });
$(this).children("ul").css({ "visibility":"visible" });
})

$('html').click(function() {
$(".dropdown ul").css({ "visibility":"hidden" });
});

$('.dropdown').click(function(event){
event.stopPropagation();
});


# this one not working
$('.subMenu').click(function(event) {
$(".dropdown ul").css({ "visibility":"hidden" });
event.preventDefault();
});

最佳答案

尝试添加此功能。

$('.dropdown ul ul li a').click(function(event) {
$(".dropdown ul").css({ "visibility":"hidden" });
event.stopPropagation();
});

单击第三层时它将关闭它,并且 event.stopPropagation() 将禁止再次重新打开它。

这是updated fiddle

关于javascript - 点击第三层菜单项后如何关闭菜单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13586916/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com